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OFFLINE-ONLINE INCENTIVE POINTS SYSTEM AND METHOD 



BACKGROUND OF THE INVENTION 

FIELD OF THE INVENTION 

The present invention relates generally to incentive point programs. More particularly, 
5 the present invention relates to offline acquisition of incentive points and online 
registration/verification/redemption of these points. 

DESCRIPTION OF RELATED ART 

Merchants have long realized that due to marketing costs, the first sale made to a 
customer is far more expensive (and thus less profitable) than ensuing sales. In order to 

10 maximize profits, most merchants work to build long-tune relationships with customers, 

yielding ongoing sales with higher and higher profits. While many merchants would be willing 
to offer lower prices to entice particular customers to stick with them and not switch to 
competitors, this is often unpractical and always expensive. Charging different customers 
different prices is difficult at many levels and even if it could be accomplished, giving the 

15 incremental profit back to the consumer defeats the merchant's goal in the first place. For this 
reason, incentive award programs were developed. 

What is an incentive award program? Incentive award programs come in two varieties - 
loyalty incentives and permission marketing. Loyalty incentive programs award "purchase 
points" to those consumers who take certain purchasing actions. A classic loyalty incentive 

20 program provides a benefit to consumers who stick with or are loyal to a merchant and not 

switch to competitors, while "punishing" those who switch from brand to brand. Typically, an 
incentive is an incremental benefit that is worthless until enough points have been earned to 
redeem for a discount or a gift. Permission marketing programs reward consxmiers with 
"attention points" for paying attention to a marketing message. 

25 The loyalty incentive program will be discussed fu^st. A highly successftil form of 

loyalty incentive award program with which many people are familiar is the airline mileage 
program, although non-mileage-based programs also are widespread. Mileage programs 
currently are conducted by ahnost every commercial airline. Travelers can earn mileage or 
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mileage points by purchasing an airline ticket and actually taking the trip. The exact number 
of miles earned by the traveler is usually calculated by some formula based on the distance of 
the trip. After accumulating a certain number of miles or mileage points, the traveler can 
redeem his miles for a free or discounted airline ticket or some other award (e.g., coffee 
5 maker, free upgrades) that he can select from a catalog. The price-shopping, airline-switching 
fickle traveler would arguably not benefit (or not benefit sooner) than the traveler who is loyal 
to one airline. 

Another incentive award program is the bottle caps collection. Typically, a soft drink 
merchant sells soft drink in a disposable package - glass bottle, plastic bottle, and cans. In the 

10 case of bottles, some soft drink merchants have sponsored promotional programs where some 
bottle cap may be worth some value. One bottle cap have an inscription saying, 'Tou have 
won! " At this point, the lucky consumer would either take his bottle cap to the store where he 
purchased his soft drink or mail them to the designated redemption center to claim his prize. 
Similar incentive award programs also have begun to flourish in an onlme environment 

15 over the Internet. Buyers can earn pomts online, for example, by purchasing goods from an 
online merchant, clicking on advertisements, filling out registrations and surveys, and 
performing various other activities of interest to merchants, advertisers and other companies. 
Users accumulate "points" into an "account" from which they can redeem their points for 
certain goods or services. 

20 Even those consumers who are not regular online users or even familiar with the 

Internet may well be familiar with a variation of the point system. Many merchants award 
discounted or free merchandise to loyal and frequent customers. For example, by ordering a 
regular meal at a restaurant on ten different occasions (recorded on a stamped card), the 
customer may get 50% off the eleventh meal (or even get the eleventh meal free). Similarly, 

25 another merchant might give a loyal customer a free drink with his meal after every seventh or 
tenth visit. Another merchant might give $10 off the next purchase for a first-thne customer. 
These variations on the loyalty incentive pouit system are just that - variations. Even though 
an actual physical card may be stamped after each visit to a restaurant or a gift certificate is 



SV/103327.01 
08142000/13:06/18568.1 



handed out, these stamps and gift certificates are analogous to points, albeit in non-electronic 
form. 

The tremendous power of loyalty incentives is this: the more points that a consumer has 
earned, the more the consumer wants points! Each incremental point is more and more 
5 valuable to the consumer because high point levels are associated with more exclusive (and 
valuable) benefits. So, the merchant benefits from the increased returns. The best customers 
are the least likely to switch to a competitor. 

Yet, despite the attraction to consumers of points that often are perceived as a "free 
bonus" for taking actions they otherwise would have taken anyway (such as traveling on an 

10 airline or purchasing an item), existing point systems have certain redemption restrictions that 
have lunited the desirability of points to consumers generally, and prevented them from 
continuing to participate in point systems on a frequent basis. After some degree of initial 
participation, consumers often are disillusioned after recognizing that they cannot obtain a 
sufficient number of points to reach their desired goal. 

15 One factor contributing to this problem is that points are not universally redeemable for 

all goods. Points typically have restrictions on redemption, including limitations to the goods 
of one or a few affiliated merchants. Miles earned for trips taken on one airline, for example, 
cannot be applied to the traveler's account with another airline. Thus, in order for the traveler 
to earn as many redeemable miles as possible within a given timeframe, the traveler must buy 

20 and use airline tickets from one airline. By being loyal to one merchant, the consumer is 

rewarded with points which he can redeem later if he accumulates enough points. Similarly, 
the consumer with die winning bottle cap can only redeem the bottle cap with that particular 
soft drink merchant and only for a limited number (usually one) of prizes. 

However, the consumer may be missing out on some bargains from other merchants 

25 because of his desire to remain loyal to the first merchant. For example, the consumer may 
continue to purchase relatively high-priced airline tickets from Jones Airlines so that he can 
accumulate miles from them instead of purchasing the relatively inexpensive airline tickets 
from Smith Airlines. Similarly, the consumer is likely to visit the expensive Joe's Tacos to get 
his card stamped after each visit so that he can get a free meal instead of visiting the less 
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expensive Tim's Tacos. Thus, the merchant-specific nature of the incentive points system 
psychologically limits the consumer's desire to purchase goods that the consumer would 
otherwise purchase because of the perceived penalty (i.e., opportunity cost) of visiting another 
merchant. 

5 From the merchant's point of view, loyalty incentives are costly. Every point that is 

redeemed by a customer costs the merchant money. While some attrition occurs (i.e., many 
points are never redeemed), the fact remains that every point awarded has a marginal cost to 
the merchant. For example, some airline companies sell "miles" to hotels and other points 
issuers for approximately 2 cents each. Thus, a very real cost to these merchants exists for 
10 every point issued to a customer. Because points cost money to issue, merchants always 

require some payment by the consumer to actually earn the points. For example, the consumer 
must purchase a plane ticket or stay in a hotel to get frequent flyer miles. 
i,0 Despite these drawbacks in the loyalty incentive programs, consumers are seeing some 

I y improvements. Although most point systems are still merchant-specific, more and more 

J; 15 merchants are forming relationships with one another so that points are more universally 
In accepted across different merchants, and thus more desirable to consumers. For example, 

I, purchasing goods from one merchant can result in earning points with another merchant. A 

:=2 consumer's use of his credit card might earn the consumer miles with Jones Airlines. 

Similarly, points earned through one merchant may be redeemable with another designated 
Q 20 merchant. Thus, the consumer is no longer restricted to one merchant's catalog at redemption 
time. 

However, there still exists no "universal" marketplace for the redemption of points. At 
best, there may exist a redemption catalog containing the goods of multiple merchants. 

Another redemption-related limitation of existing point systems is that points can only 
25 be redeemed after certain point thresholds have been reached. For example, Jones Airlines 
might award a free domestic round trip ticket only after the customer has earned 3,000 miles. 
A customer with 2,999 miles knows that these 2,999 miles is worthless until that last 1 mile 
has been earned to qualify for that 3,000 mile threshold. Similarly, only after the tenth visit to 
Joe's Tacos will the customer be eligible for a ft-ee meal. In each of these cases, if the 
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customer has earned even one point, one mile, or one visit less than the required redemption 
threshold, the customer will not be able to redeem his points, miles, or visits for the desired 
goods or services. 

Finally, points typically expire after a certain specified time period. The merchant 
5 benefits in that customers are motivated to redeem points as the expiration date approaches to 
avoid losing the points forever. Similarly, if the point total is below the redemption threshold, 
the customer may be motivated to take some action (e.g., purchasing a product, clicking on an 
ad, registering with a website) to earn enough points so that he may redeem them and not 
subject his already-earned points to expiration. 

10 Yet, the "fixed-price" nature of redemption continues to Ihnit the desirability of points 

to consumers, as well as the effectiveness of expiration. Over time, consumers may lose 
interest (and even let their points expire) as they recognize that the items they desire in the 
redemption catalog (which require a specified point total) may take a long time to obtain given 
the current rate at which points are being accumulated. 

15 Were there an alternative form of redemption that provided consumers with a greater 

perceived opportunity to obtain desirable items, consumers might be more motivated to 
participate in incentive award programs with greater frequency. If consumers thought they 
could obtain their desired items, almost regardless of the number of points they had 
accumulated, they might be less disillusioned by the prospect of expiration of their points. 

20 Thus, incentive award systems have demonstrated the viability of altering consumers' 

behavior if consumers perceive the points to be of value. Yet, the fixed-price nature of point 
redemption in existing incentive award systems often has limited the perceived value of points. 

Another limitation with existing point systems is the rigid boundary that exists between 
online and offline purchasing channels. While a consumer that purchases some merchandise at 

25 an online web store can also earn incentive points for that purchase and redeem them at that 
online web store, he cannot redeem them offline at a traditional bricks-and-mortar store. 
Similarly, incentive points earned at a traditional bricks-and-mortar store can only be redeemed 
at that bricks-and-mortar store, but not any some odier online web store. 

The soft drink bottle cap is one example. The lucky consumer with the winning bottle 
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cap from Joe's Cola Company can only redeem them in one of three ways, depending on the 
bottle cap program: (1) mail the winning bottle cap to Joe's Cola Company's redemption 
center; (2) call the appropriate telephone number of Joe's Cola Company's redemption center; 
or (3) take the winning bottle cap to the store where he purchased the soft drink where he can 
5 then claim his prize. In the past, this made sense. The consumer purchased his product offline 
at the store so he must also redeem (i.e., claim his prize) offline. 

What is needed is a system, preferably an automated online system, that provides the 
benefits of incentive award programs (i.e., loyalty incentives), but without the disadvantages as 
noted above. Furthermore, the system should also provide flexible redemption capabilities 
10 across offline-online boundaries so that any points earned offline can be redeemed online, and 
similarly, any points earned online can be redeemed offline. The present invention provides 
such an enhanced account-based online system. 

SUMMARY OF THE INVENTION 

The present invention provides solutions to the aforementioned problems by integrating 
15 online-offline incentive points earnings with online-offline points redemption. In particular, 
one embodiment of the present invention allows users to redeem online those points that were 
earned offline in a server-based system called the Integrated Points System. 

In one embodhnent of the present invention, the Integrated Points System is 
implemented as an online server that is accessible, via a web browser, to those consumers who 
20 have access to the Internet. The server includes a web server, a messaging server, a database 
server, and various databases. 

This server functionality can be implemented on a single hardware platform having one 
or more web servers, or can be distributed among multiple hardware servers, each having one 
or more web servers and handling one or more of these functions (e.g., integrated web server 
25 and messaging server). This functionality includes conventional web server and application 
server functionality, such as running applications, managing resources, handluig web requests, 
managing files and records, delegating tasks, and handling exceptions, among other tasks. 

One particular implementation of the Integrated Points System involves soft drink bottle 
caps. For offline-online points processing, the user first acquires a soft drink bottle cap. On 
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the bottle cap itself is a C-digit code made up from an alphabet of L letters. In one 
embodiment, the alphabet consists of 29 letters (e.g., L=29) to generate a 10-digit code (e.g., 
C = 10). Theoretically, this 10-digit code is difficult to predict - the odds of guessing the 
correct code is approximately 1 in 200,000. So, without the soft drink bottle cap, a user would 
5 find some difficulty in determining what code to register online. 

To generate these codes, an encryption scheme is employed. The encryption scheme 
involves generating a 48-bit string that includes a number portion and a validation portion. 
Based on the number portion and a secret key, another string is created using a well known 
one-way hash function, such as the MD5 algorithm. Some designated portion of this new 

10 string is extracted and used as the validation portion of the 48-bit string. Having generated this 
48-bit string, the standard DES3 encryption algorithm is applied to generate another string, 
which is then converted to base L (e.g., L=29) to generate the C-digit code (e.g., C = 10). 
This code is then printed on the bottle cap - one code per bottle cap. 

To verify that the bottle cap code that the user submitted online is indeed a valid bottle 

15 cap code, the server performs the reverse of the encryption operation except for the MD5 one- 
way hashing operation which is run forward. It first converts the base L code into base 2. It 
then decrypts the base 2 number to generate a string SI'. Using one of designated secret keys, 
the server applies the MD5 one-way hash operation to the number portion of the SI' string to 
generate a new strmg S3'. The validation portion of this new string S3' is then compared with 

20 the validation portion of the string SI'. If they match, the code is valid; if no match, the code 
is invalid. 

The user accesses a designated web page, which is typically the soft drink 
manufacturer's home page or some web portal (e.g., Yahoo) that is sponsoring the bottle cap 
promotion program. The user would register himself with the website, if he has not done so 
25 already, to set up an account. Thereafter, the account keeps track of his incentive points as 
they are earned, redeemed, or otherwise expired. 

The user would enter the bottle cap code in the appropriate web page. The server 
checks the code to make sure it is one of the valid codes. If it is a valid code, the server adds 
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the corresponding points to the user's account and checks off that valid code in the database so 
that the same code cannot be used again by this or another user. 

BRIEF DESCRIPTION OF THE FIGURES 

The description of the present invention may be better understood with the aid of the 
5 following text and accompanying drawings. 

FIG. 1 shows a network environment of client computing stations and server stations 
within which one embodiment of the present invention operates. 

FIG. 2 shows one embodiment of the server computing system which provides the 
numerous functions and features of the Yahoo! Auction System. 
10 FIG. 3 shows a flowchart that illustrates the manner in which payment units such as 

Yahoo! Points are issued to users. 

FIG, 4 shows the operation of the Yahoo! Auction System and the unplications to the 
users' accounts when implementing the Standard Auction format where a single item is being 
auctioned off in accordance with one embodiment of the present invention. 
15 FIG. 5 shows the operation of the Yahoo! Auction System and the implications to the 

users' accounts when implementing the Standard Auction format where multiple items are 
being auctioned off in accordance with another embodiment of the present invention. 

FIG. 6 shows the operation of the Yahoo! Auction System and the unplications to the 
users' accounts when implementing the first embodiment of the Dutch Auction format. 
20 FIG. 7 shows the operation of the Yahoo! Auction System and the implications to the 

users' accounts when unplementing the second embodiment of the Dutch Auction format. 

FIG. 8 shows the operation of the Yahoo! Auction System and the implications to the 
users' accounts when implementing the Progressive Auction format where multiple items are 
being auctioned off in accordance with a further embodiment of the present invention. 
25 FIG. 9 shows the operation of the Yahoo! Auction System and the implications to the 

users' accounts when implementing the Buy-or-Bid Auction format where multiple items are 
being auctioned off in accordance with still another embodiment of the present invention. 

FIG. 10 shows the operation of the Yahoo! Auction System and the implications to the 
users' accounts when implementing the automated bidder feature in accordance with an 
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embodiment of the present invention. 

FIG. 11 shows the operation of the Yahoo! Auction System and the implications to the 
users' accounts when implementing the Declining Auction format where multiple items are 
being auctioned off in accordance with still another embodiment of the present invention. 
5 FIG. 12 shows the Integrated Pomts System in accordance with one embodiment of the 

present invention where all the components are widely distributed. 

FIG. 13 shows a detailed view of the web server of the Integrated Points System where 
all the components are centrally located. 

FIGS. 14(A) to 14(E) show screenshots of the various pages that are presented to the 
10 user when the user accesses the Integrated Points System's server in accordance with one 
embodiment of the present invention. FIG. 14 (A) shows the home page of the Integrated 
Points System (without the graphics) where the user can shop, enter a bottle ap code, or view 
his account. FIG. 14(B) shows the web page that allows the user to enter the bottle cap code. 
FIG. 14(C) shows the webpage that shows some indication that the user entered a valid bottle 
15 cap code. FIG. 14(D) shows the webpage which lists items that the user can purchase with his 
available points. FIG. 14(E) shows a table of items that can be purchased and/or bid (via 
auction), as well as any available coupons for these items. 

FIG. 15 shows a flow diagram of the encryption process in accordance with one 
embodiment of the present invention, 
20 FIG. 16 shows a flow diagram of the verification process in accordance with one 

embodiment of the present invention. 

FIG. 17 shows the structure of the code production database and the contents in 
accordance with one embodiment of the present invention. 

DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS 

25 The first part of this patent specification will discuss the electronic auction system 

where the auction is conducted online with points in various auction formats. The second part 
of this patent specification will discuss the offline-online incentive points system where users 
acquire incentive points offline (e.g., soft drink bottle cap program) and verify diese points 
online to accumulate these points in their respective accounts. With such an account that keeps 
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10 



15 



20 



track of the acquisition and redemption of points, users can purchase or win merchandise, 
services, and prizes. 

This DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS section is 
structured as shown in the following outline: 



1.0 


Network Configuration 


2.0 


Server Configuration 


3,0 


Account Database 


4,0 


Yahoo 


! Points 




4.1 


General 




4.2 


Earning Points 




4.3 


Redeeming Points 




4.4 


Policies and Abuse Control 




4.5 


Controls on Outstanding Points 




4.6 


Point Issuance by Offer Server 


5.0 


Management Tools 


6,0 


Auction Formats 




6.1 


Standard Auction 




6.2 


Dutch Auction 




6.3 


Progressive Auction 




6.4 


Buy-or-Bid Auction 




6.5 


Declining Bid Auction 



7.0 Automated Closing 

8.0 Auction Alert 

25 9.0 Automated Bidder 

10.0 Automated Seller 

11.0 Account Checks Beyond the Initial Check 

12.0 Point Credit 

13.0 Yahoo ! /Merchant Relationship 
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14,0 Integrated Points System 

14.1 Network Architecture 

14.2 Network Operation 
14.2.1 System Overview 

5 14.2.2 Encryption 

14.2.3 Verification 

14.2.4 Database Management 



One embodiment of the present invention is an electronic auction system that allows 
10 merchants and buyers to participate in auctions using any form of payment unit that is 

permitted by the seller. For the sake of clarity, the electronic auction system and its variations 
will be referred to herein as the "Yahoo! Auction System" or, in some instances, simply "the 
system. " 

One form of payment unit is incentive points that can be earned in many ways, such as 
15 purchasing a product/service, clicking through an advertisement, or registering with a 

merchant. Other ways of earning points are described further below. The Yahoo! Auction 
System allows potential bidders to bid on auction merchandise with their points. 

As described further below, each participant in the Yahoo! Auction System has an 
account which keeps track of his accumulated points. When bidding for or purchasing any 
20 merchandise, the Yahoo! Auction System checks the participant's account balance to determine 
if such a bid or purchase can be made. Additionally, some participants' accounts may have a 
credit feature which allows the participant to bid on or purchase merchandise whose price tag 
exceeds the current account balance (whether in points or cash), provided that the specified 
credit limit is not exceeded. 
25 1.0 NETWORK CONFIGURATION 

In accordance with one embodiment of the present invention, the Yahoo! Auction 
System is implemented in an online networked environment. As shown in FIG. 1, a typical 
network environment includes some client computer stations 101, 102, and 103 that are usually 
operated by a human participant (e.g., potential bidder) of the Yahoo! Auction System. These 
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client computer stations are connected to the wide area network (WAN) of the Internet 120 via 
Internet Service Providers, or ISPs (not shown in FIG. 1), Other client computer stations 104 
and 105 are part of a local area network (LAN) 100. This network also contains a server 
computer station 106. Server computer stations 110, 111, and 112 provide various 
5 functionality over the web. Each server can be accessed by their identifying uniform resource 
locator (URL) address (i.e., "http://www.Yahoo.com"). The Yahoo! Auction System is a 
computer program that resides in and is executed primarily in at least one of these server 
computer stations, such as server 112. 

In one embodiment, the various auction-related screens use HTML. Other 

10 embodiments use XML (i.e., static objects from which various HTML pages could be 
generated dynamically) or some other format. The functionality of server 112 will be 
discussed in greater detail below. 

Client computer stations 101-105 are usually operated out of private residences, small 
offices, or even large corporate offices. Representative client computer stations are personal 

15 computers with modems (or network connections, e.g., to a router and high-speed Internet 
connection), terminal stations, and network servers. The client computer station is complete 
with a computer, keyboard, mouse, monitor and appropriate modem/bus/network interface. 
As known to those ordinarily skilled in the art, a representative client computer station 
includes a CPU, a local bus, a host/PCI bridge, memory bus, main memory, and hard disk 

20 memory. Exemplary client computer stations include a Sun Microsystems SPARC or ULTRA- 
SPARC workstation, an Intel/Microsoft-based computing station (e.g., Gateway, Dell, 
Micron), and the Apple Macintosh. These client computer stations are capable of supporting 
various operating systems, including Solaris, Windows 98, Windows NT, and the Apple OS. 
Applications that run on these client computer station include email (e.g., Microsoft 

25 Outlook Express, CCMail), web browsers (e.g., Netscape Navigator, Microsoft Internet 
Explorer), web servers, and community-based online services (e.g., AOL, CompuServe, 
Prodigy). Access to the Yahoo! Auction System is made possible through a web browser for 
viewing web content in the form of HTML files. Through the web browser, cookies may also 
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be used to store state information such as user name, ID, password, user preferences, settings, 
and the like, as known to those skilled in the art. 

The email system can also be used to access the Yahoo! Auction System for such tasks 
as bid submission, receiving notifications that the user has been outbid, or simply to alert the 
5 user of other auctions that he may be interested in. 

The corporate network 100 is usually implemented as a local area network (LAN) for 
intra-building or intra-campus communication. Where the corporate network 100 extends to 
multiple buildings or multiple campuses in different geographic locations, the corporate 
network 100 can be implemented as a wide area network (WAN) for inter-building or inter- 
10 campus conmiunication that extends the individual LANs via common telephone carrier lines. 
These WANs typically employ bridges or routers to enable the communication over the 
common carrier lines. 

In one embodiment, the server 106 in the LAN network 100 may perform the auction 
functionality described in this patent specification. Thus, a company operating this network 
15 100 can award points to its employees and allow them to participate in certain auctions for 
various prizes. 

2.0 SERVER CONFIGURATION 

A server computer station 112 associated with the Yahoo! Auction System will now be 

discussed with respect to FIG. 2. At the core of the server 112 is a web server 137 which 
20 interfaces with a database server 136, a messaging server 138, and the Internet 150. The web 

server 137 is further coupled to communications lines 143 (e.g., via a modem or network 

router connected to server 112) and the Internet 150. 

The web server 137 performs many tasks related to the management of the Yahoo! 

Auction System. From executing code for any number of different applications, managing 
25 resources, handling web requests, managing files and records, creating files and records, 

deleting files and records, delegating tasks, and handling exceptions, the web server 137 

provides the maui processing for the server 112. As noted above, this functionality, in other 

embodiments, could be distributed across multiple hardware servers. 



13 



SV/103327.01 
081420(X)/13;06/I8568.i 



The web server 137 also works with a messaging server 138 via line 142 (e.g., the 
system bus or a network connection to another hardware server) and a database server 136 via 
line 141. The messaging server 138 works with the web server 137 via line 142 and is also 
connected to the Internet via communication lines 144, The messaging server 138 provides 
5 various messaging functionality in various communications media such as telephone, email, 
instant messaging, active desktop application, and web browser notices. For example, email 
notices such as auction news, auction updates, and auction customer service access, are 
provided via communications line 144. News of upcoming auctions that may interest the 
potential bidder are delivered frequently. Also, when a bidder has been outbid by another 

10 bidder, the losing bidders are notified of the new high bid by the messaging server 138 via 
communications lines 144. By responding appropriately, the bidder can submit a new higher 
bid with email that will be handled by the messaging server 138 via communications lines 144. 
Also, any questions that a user may have may be directed to customer service through the 
messaging server 138, which will direct the email to the appropriate personnel within the 

15 customer service department. As noted above, various forms of instant messaging as are well 
known in the art could replace some or all of the functionality of messaging server 138. 

Note that communications lines 143 and 144 are standard interfaces to the Internet 
(e.g., an Ethernet or o±er network interface to a router and CSU/DSU, modem, etc.) or 
across machines which are typically Ethernet-connected at the "back end" of the network. 

20 In another embodiment, the web server 137 and messaging server 138 are integrated in 

an Internet server 146. The interface to the Internet 150 is provided by primary 
communications line 144 (line 143 is not implemented). Thus, all web traffic passes through 
this Internet server 146 via communications line 144. The messaging server 138 
communicates with the web server 137 and the back end of the system (e.g., database server 

25 136). 

The database server 136 is a combination of all of the auction and related functionality. 
Specifically, it performs many tasks related to the creation, deletion, and management of 
various files and records managed by the server 112. The database server 136 supports the web 
server 137 in accomplishing its tasks of running the Yahoo! Auction System. The database 
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server 136 serves an auction database 130, a merchandise database 131, a seller database 132, 
a bidder database 133, an account database 134, and a bid database 135. These databases 130- 
135 are coupled to a communications line 140 and to the database server 136. Note that the 
sellers access the management tools via the Internet through a web browser. 
5 These databases on communications line 140 comprise the "back end" of the system. 

Note that the common bus-like illustration of the communications line 140 is merely 
conceptual. The databases may not actually be on a common bus. These databases may be 
widely dispersed geographically or integrated into one database. Also, some of the databases 
may be on a common bus while others may be located remotely and accessed via the Internet. 

10 These databases contain appropriate linking fields so that an entry in one database can 

be associated with a related entry in another database. For example, assume that a seller wants 
to auction off a bicycle in an online auction through the Yahoo! Auction System. Information 
about the seller is found in the seller database 132, information about the seller's account is 
found in the account database 134, information about the bicycle is found in the merchandise 

15 database 131, mformation about that auction for the bicycle is found in the auction database 
130, information relating to any bids that have been received for that bicycle during the auction 
is found in the bid database 135, and information about bidders who have submitted bids for 
that bicycle is found in the bidder database 133. 

The auction database 130 stores information about each auction, whether currently 

20 active, completed, or upcoming. The information includes parameters that either the Yahoo! 
Auction System or the seller specifies such as starting bid price, starting bid price decrement, 
number of times to calculate the new startuig bid price, start-up time period, time period of 
auction, whether float closing feature is enabled, bid increment (or bid increments at each of 
the auction phases), and sell-off threshold. These parameters are stored in the auction database 

25 130 with appropriate indices to the matching merchandise in the merchandise database 131 and 
the seller in the seller database 132. These parameters will be discussed in greater detail below 
in conjunction with the different auction formats. 

The merchandise database 131 contains merchandise that the merchants put up for 
auction. If available, each item of merchandise is associated with a text description, an image 
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file or drawing, a video file, and the seller ID. Each auction item is associated with some 
identifier so that the database server 136 can track the same item across multiple databases. 
Thus, a given item in the merchandise database 131 is associated with a seller in the seller 
database 132, the current high bid in the bid database 135, and all bidders (successful or not) 
5 in the bidder database 133. 

The seller database 132 contains the names of sellers, whether corporate merchants or 
individuals, and respective identifiers. Normally, the sellers need to register and set up an 
account in order for the seller's name to be placed in the seller database 132. The account 
provides a repository for points, whether earned through an auction sale or designated for 

10 distribution to potential customers. Moreover, sellers may also be buyers in a different 
transaction and accordingly, their accumulated points must also be tracked. Some 
representative seller information includes name, ID, and ratings submitted by other users of the 
Yahoo! Auction System, Thus, if one bidder had a bad (or good) experience with a particular 
seller, he may write an assessment of that seller or rate that seller and submit his review and 

15 rating to the Yahoo! Auction System. This allows other users of the Yahoo! Auction System to 
obtain a better understanding of this particular seller's transaction behavior and product 
quality. 

The seller database also contains the names of those bidders that the seller prefers to 
block from bidding in certain or all auctions. For whatever reason, from bad prior experience 

20 with a particular bidder or reported bad behaviors, the seller may block certain bidders from 
participating in the seller's auctions. In another embodiment, this information can be stored in 
the auction database 130 instead of the seller database 132. In this way, the seller may allow a 
selected bidder to participate in one auction but prevent that same selected bidder from 
participating in another auction. 

25 The names in the seller database (as well as the bidder database) are in the form of 

YahooIDs. A YahooID is a unique string that identifies a Yahoo! user along with a password. 
In another embodiment, the YahooID is analogous to domains to allow users to use identical 
user names across different domains. Thus, the user with the YahooID or user name 



16 



SV/103327.01 
08142000/13:06/18568.1 



"JoePublic" in Yahoo's shopping or auction website can also use the same user name 
"JoePublic" in GeoCities. 

The bidder database 133 contains the names (e.g., YahooID) and other information 
about the bidders. Normally, the bidders need to register and set up an account in order for the 
5 bidder's name to be placed in the bidder database 133. The account provides a repository for 
points, whether earned through an auction sale or designated for distribution to potential 
customers. Moreover, bidders may also be sellers in a different transaction and accordingly, 
their accumulated points must also be tracked. Some representative information includes 
name, ID, and ratings submitted by other users of the Yahoo! Auction System. Like the 

10 ratings for the seller, the bidder rating allows other users of the Yahoo! Auction System to 
obtain a better understanding of this particular bidder's transaction behavior. 

In another embodiment, the seller database 132, the bidder database 133, and the 
account database 134 are integrated into one database. In this case, the single database does 
not distinguish between buyer/bidder and seller since every seller can also be a buyer and 

15 every buyer can also be a seller. 

The account database 134 contains information about each participant's account, 
whether buyer or seller. The account information includes account balance, expiration date for 
each point or group of points, redemption information, credit card information, billing 
information, billing address, and whether the account is authorized for using points for credit. 

20 The account database 134 will be described in greater detail below in the ACCOUNT 

DATABASE section of the patent specification. Although this embodiment illustrated in FIG. 
2 shows the account database 134 integrated with the rest of the Yahoo! Auction System, 
another embodiment may have the account database located in a third party's server and 
maintained by the third party. 

25 The bid database 135 contains information about any and all pending bids. Regardless 

of whether the bids are currently the high bid or not, the bid database keeps track of all valid 
bids (and, in another embodiment, invalid bids as well). The record of all bids allows the 
Yahoo! Auction System to award multiple items to multiple top bidders who may not 
necessarily be the highest bidder for such auction formats as Standard Auction, Dutch Auction, 
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Progressive Auction, and Buy-or-Bid. Additionally, a record of all bids facilitates dispute 
resolution if any competing bidders lodge any complaints about the bidding process for any 
given auction. 

In one embodiment, these databases are distributed across one or more machines. 
5 These machines are coupled via communications line 140 to the database server 136. These 
databases comprise the "back end" of the system which the Internet server 146 access. 

Another component (not shown in the figure) is the server that provides the actual 
Yahoo! Auction System web page. This server provides the Yahoo! Auction template along 
with the auction content that the bidders and merchants view. When a user sends a request to 

10 the Yahoo! Auction website with his browser, the server responds to this request by delivering 
the Yahoo! Auction template to the user for display by the user's browser. 

The Yahoo! Auction template contains the web pages that display auction functionality 
such as bidder services, merchant services, merchandise categories, auction news, and Yahoo! 
Shopping. Bidder services include such functionality as browse, bid, auction selection, 

15 account creation, search engine, and help (FAQs). Merchant services include such 
functionality as placing merchandise up for auction and account creation. Merchandise 
categories allow the auction participants to view the various items of merchandise in groups or 
categories to make searching easier. Exemplary merchandise categories include antiques and 
collectibles, arts and entertainment, business and office, clothing and accessories, computers, 

20 electronics and cameras, home and garden, sports and recreation, toys and games, trading 
cards, transportation, and other goods and services. Auction news deliver the latest news on 
auctions in general and Yahoo! auctions in particular. Yahoo! Shopping provides participants 
to shop at any participating merchant's website. Other standard features like site maps, "About 
Yahoo! Auctions," Feedback, Contact Yahoo, and legal notices are also provided on the 

25 Yahoo! Auction template. A "My Yahoo! Auctions" feature allows the user to personalize this 
web page view. 

With this web page, users will be able to view their respective balance summaries 
(including last N transactions or full transaction histories), expiration dates for each group of 
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points, redemption histories, names of merchants that the points were acquired from, and 
names of merchants that the points were redeemed, among other information. 
3.0 ACCOUNT DATABASE 

The account database 134 comprises a user database (UDB) 151 and a relational 
5 database (RDB) 152, as shown in FIG, 2, which will be maintained in synchronization with 
each other. The user database (UDB) 151 is used for speed-intensive applications, such as 
real-time access from production websites. When the offer server 139 awards points, the 
user's UDB record will be modified to reflect the transaction. The offer server 139 notifies the 
user that his account balance has been increased (via email or the website). The UDB 151 is 

10 also used for redemptions. Upon some redemption action, the Yahoo! Auction System checks 
the UDB 151 for available points for a specific user and a specific transaction, determines 
eligibility, and either debits the account for the desired number of points for an actual 
transaction or places the desired number of points on reserve for a potential transaction. 

In one embodiment, the UDB is implemented as a hierarchical, non-relational directory 

15 flat file system. The UDB incorporates a tree structure to find the desired account record. For 
example, to find the account record for "Betty Jones," the system looks for "J" among the tree 
structure of last names beginning with A-Z. Having found J, the system then seeks "Jones. " 
If multiple Jones's are found, the system then looks for "Betty" (as in "Betty Jones"), and so 
forth until a unique record is located. In another embodiment, the account that keeps track of 

20 Yahoo! Points is maintained in a separate third party server's database. 

The relational database (RDB) 152 is used for logging points, running expiration 
scripts, providing customer care with accurate records, and the like. It is also used by the 
offer server 139 to record and track all transactions, which includes processing information 
such as OfferlD, time/date stamp, YahooID, the actions that the user took to earn his points, 

25 and the like. Only some of the information in the RDB 152 is accessible by the user. In other 
embodiments, none of the information in the RDB 152 is accessible by the user, except for 
customer care and other authorized Yahoo! employees. Every transaction that the user is 
involved in is recorded and tracked in the RDB 152. 
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In one embodiment, points expire one year from the end of the calendar quarter in 
which they were earned (refer to the discussion in the "Policies and Abuse Control" section 
below). To incorporate the expiration date into each account, each account comprises five 
buckets (Bl, B2, B3, B4, B5), A bucket represents a calendar quarter. When points are 
5 earned, they are placed in the first bucket Bl, which corresponds to the present quarter. 

Bucket Bl always represents the current quarter. At the start of the next calendar quarter, the 
points from Bl are transferred to bucket B2, the pomts that were in B2 are transferred to B3, 
the points that were in B3 are transferred to B4, the points that were in B4 are transferred to 
B5, and the points that were in B5 are removed altogether. Thus, these points that were in 

10 bucket B5 and removed represent the expired points. At the start of the next calendar quarter, 
the cycle repeats again as the points that are in bucket B5 will be removed. 

In another embodiment, each accoimt comprises five buckets (Bl, B2, B3, B4, B5). A 
bucket represents a particular calendar quarter. Unlike the previous embodiment, however, 
bucket Bl does not necessarily always represent the current quarter. When points are earned, 

15 they are placed in whatever bucket corresponds to the present quarter. To implement the 
expiration feature, at the start of a calendar quarter, the contents of the bucket corresponding 
to this new calendar quarter are erased. Thus, whatever points were in this bucket have now 
expired and are no longer available to the user of this account for redemption. For example, 
assume that today is December 5, 1999. The user earns 10 points by clicking on an ad on 

20 Yahoo! 's website. Bucket B4 represents this quarter. Bucket B5 represents the next quarter 
which begins on January 1, 2000 and ends on March 31, 2000; bucket Bl represents the 
quarter from April 1, 2000 to June 30, 2000; bucket B2 represents the quarter from July 1, 
2000 to September 30, 2000; bucket B3 represents the quarter from October 1, 2000 to 
December 31, 2000. Also, bucket B4 now represents the quarter from January 1, 2001 to 

25 March 31, 2001. Remember, the user had earned 10 points on December 5, 1999 and these 10 
points were placed in bucket B4. At the beginning of the quarter on January 1, 2001, the 
contents of bucket B4 are erased. So, if the user had not redeemed his 10 points by January 1, 
2001, these 10 points and whatever other points in bucket B4 are erased. 
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Points in the account are also encrypted to prevent unauthorized users from accessing 
and/or modifying point totals and otherwise interfering with user accounts. 

The concept of "reservation" is applied to the account database in one embodiment of 
the present invention. Assume that a user has N points (e.g., 100 points) in his account. If a 
5 user bids on an item in an auction using some fractional amount, say M points (e.g., 20 points) 
of the N points, this fractional amount M is reserved or set aside by the system in some 
temporary subaccount. All N points are still in the account but only those points that are not 
reserved (i.e., N-M points) are available to the user for other transactions until this particular 
auction in which the M points are reserved has resolved the user's status (i.e., win, lose). If 
10 the user wins, these M points (or some portion thereof depending on the type of auction) are 
used for the sale (i.e., these M points are deducted from the user's account permanently to 
complete the transaction). If the user loses, these M points are unreserved so that all N points 
are available to the user. The variations on the reserve/unreserve process are described below 
with respect to the various auction formats. 
15 4.0 YAHOO! POINTS 

4.1 GENERAL 

In accordance with one embodiment of the present invention, the Yahoo! Auction 
System uses payment units, which can be in the form of actual points (and credit points) or 
cash (and credit). Although any form of payment unit can be used in the Yahoo! Auction 

20 System of the present invention (including a mixture of cash and points within a single 
auction), the patent specification will describe the embodiments with respect to points. 
However, one skilled in the art will recognize that the implementation details will be similar if 
money or alternative forms of currency were used instead of points. 

In accordance with one embodiment of the present invention, the points are known as 

25 Yahoo! Points. Yahoo! Points can be either purchase points or attention points. These points 
are part of a rewards system that rewards users who use Yahoo's network of online properties, 
particularly Yahoo's e-commerce properties. Although Yahoo! Points can be viewed as a 
separate form of currency to purchase products conventionally or through an auction, Yahoo! 
Points are better viewed as a means of building a mutually beneficial relationship between the 

21 

SV/103327.01 
08142000/13:06/18568.1 



merchants and the buyers. Thus, as users earn more and more Yahoo! Points, the users are 
rewarded with gifts and redeemable merchandise, while merchants are rewarded with more 
sales-generating traffic on their websites. 

Yahoo! Points may have a dollar-equivalent value internal to Yahoo, but may not 
5 necessarily have a direct cash value to users. Thus, in one embodiment of the present 

invention, users are not allowed to convert Yahoo! Points into cash. In another embodiment, 
Yahoo! Points can be converted into cash, provided that users adhere to certain conversion 
rules, analogous to redemption rules. 

Note, however, that Yahoo! may not allow any conversion at all so as to operate a zero- 
10 marginal cost point system; that is, if conversion for cash is allowed (for whatever amount), 
each point will cost Yahoo! or a participating merchant some amount of money as users ask for 
conversion into some dollar-equivalent value. 

4.2 EARNING POINTS 

Because Yahoo! is a high traffic website, numerous merchants have made arrangements 
15 with Yahoo! to make Yahoo! Points an accepted form of payment unit. Thus, merchants 

award Yahoo! Points to consumers, and allow for their redemption, in numerous ways. More 
importantly, these participating merchants have made these Yahoo! Points so universal that 
Yahoo! Points earned through one merchant can be redeemed with another merchant, and vice 
versa. Additionally, Yahoo! Points can also be converted into miles for many frequent flyer 
20 programs, and vice versa. 

These Yahoo! Points can be earned in any number of ways, such as by registration, by 
purchase of product/service, and by viewing advertisements. The consumer is not necessarily 
required to visit the Yahoo! site to earn points; rather, Yahoo! Points can be earned through 
any website that awards Yahoo! Points (i.e., those merchants with some relationship to 
25 Yahoo). 

One common way of earning points is by registering with a website. The registration 
process asks for basic consimier information such as name, address, age, sex, family size, 
occupation, income level, product preferences, interests, alias (or user ID), password, and 
information that is specific to the product/service that the merchant is trying to sell. The 
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consumer may also be asked to provide billing information such as credit card number, 
expiration date, name on credit card account, and billing address, although many websites may 
delay requesting this information until the consumer has made an actual purchase. By 
registering, the merchant sets up an account for the consumer. The merchant then credits the 
5 consumer's just-created account with the points earned for going through the registration 
process. The merchant also logs the date that these points were earned for the purpose of 
determining expiration. 

Points can also be earned by purchasing a product or service. For example, by 
purchasing airline tickets, the consumer has the potential to earn a specific number of miles. 

10 When he actually takes the trip, the merchant will then credit his account with the earned 
miles. In another embodiment, the user need not actually take the trip to earn the miles; 
rather, the merchant or Yahoo! Will issue points to the user when the user's credit card is 
charged for the airline travel. The merchant calculates the earned miles with some formula 
that is based prunarily on the distance of each leg of a trip. Similarly, purchasing a product 

15 such as a compact disc (CD) may enable the consumer to earn points immediately. The 

specific number of points earned is merchant-specific. In one embodiment, earned points and 
dollar amount spent on the purchase have a 1:1 relationship; that is, for every dollar spent, the 
merchant awards the consumer with a point. In another embodiment, the earned points and 
dollar amount spent have a 10:1 relationship so that for every dollar spent, the consumer will 

20 earn 10 points. Other fixed (e.g., 5:1, 20:1) or variable relationships (e.g., x:l where x varies 
from day to day) are of course possible. 

Points can also be earned by viewing an advertisement. For example, a merchant 
places an ad in a website, preferably a high traffic site such as Yahoo's Internet portal. 
Through various means, the ad attracts die eye of the consumer. By clicking on the ad, the 

25 consumer's browser retrieves another web page which gives the consumer more information 
about the product/service/merchant info that was the focus of the ad. The ad may initially 
indicate that the consumer may earn a certain number of incentive award points by clicking on 
the ad. Alternatively, die ad may requke the consumer to jump through some hoops first 
before the points are actually delivered. By clicking on the ad and following any additional 
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instructions, the merchant awards the promised number of points to the consumer's account, if 
one exists. If the account does not exist, the merchant assists the consumer in setting up an 
account through a registration process. 

Yahoo! Points can also be earned in other ways. Consumers can earn points from 
select merchants by; 

(1) switching long distance carriers, 

(2) updating user registration information periodically (to track changing interests) 

(3) trying out a new service with an already existing membership, 

(4) signing up for a new credit card, 

(5) entering a merchant-sponsored sweepstakes, 

(6) signing up for a trial membership to any merchant-sponsored club, 

(7) playing online games such as poker, blackjack, and slots, 

(8) answering questions for an online poll, 

(9) trying a new product with no obligations, 

(10) requesting a free quote on a vehicle, 

(11) submitting a valid bid in an auction, 

(12) submitting a winning bid in an auction, 

(13) visiting a website (although some registration may be involved), 

(14) writing and submitting product reviews (e.g., books, music, video), 

(15) downloading software from a website, 

(16) signing up a friend to some club membership, 

(17) serving an online community by answering user questions, 

(18) issuing points based on past behavior; that is, if a person does three things in 
one day, the number of points earned on the third action could be greater than that 
earned by someone who took two days to perform all three actions, 

(19) issuing bonus points for reaching certain milestones; that is, if a user has earned 
a large number of points (e.g., 100,000 points), Yahoo! could reward this good 
customer with bonus points just like first class customers on airline mileage 
programs get bonus miles, 
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(20) Points could be awarded as a multiplier (i.e., "Click here to double your 
points"), 

(21) Points could be awarded offline as well (e.g., for using a shopping card at a 
supermarket), and 

5 (22) purchasing a threshold amount of goods from multiple merchants. 

This list is merely representative of the ways in which points can be earned. This list is 
not meant to be a comprehensive list. As mentioned above, these Yahoo! Points are 
universally accepted among the participating merchants. Thus, points earned through one 
merchant can be redeemed through another merchant. So, when a consumer earns 50 points 

10 through a music merchant by purchasing some compact discs, that consumer can redeem those 
earned 50 points with a pet supply merchant to purchase dog food. Of course, the music 
merchant may have one set of rules on how to earn these points and the pet supply merchant 
may have a different set of rules on how and when to redeem points and what thresholds are 
required for redemption. So long as these rules are observed, the consumer can use points like 

15 cash and apply them across different merchants. 

Yahoo! Pouits can also be converted into some other incentive program's units or actual 
money. An example of another incentive program is frequent flyer mileage programs. In one 
embodiment of the present invention, Yahoo! Points can be converted into miles at a 
conversion rate of 1:1; that is, each Yahoo! Point is worth a frequent flyer mile. In another 

20 embodiment, the conversion rate varies from day to day, much like international currency 
conversion rates fluctuate depending on the currencies involved, the politics of the respective 
countries, and the health of these countries' respective economies, among other dynamics that 
affect international currency conversion rates. Conversely, frequent flyer miles can also be 
converted into Yahoo! Points at analogous conversion rates; that is, either 1:1 rate or a rate 

25 that varies from day to day. 

Yahoo! Points may also be convertible into cash. Like the points-to-mileage 
conversion, the conversion rate can be fixed at one point for every 1/100 of a penny. In 
another embodiment, the conversion can vary from day to day. The conversion from money to 
Yahoo! Points is also possible. 
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In another embodiment, users are allowed to buy Yahoo! Points with payment units 
such as cash. This allows those users who are otherwise deficient on points to accumulate the 
needed points to conduct whatever transaction he desires. 
4.3 REDEEMING POINTS 
5 Although Yahoo! Pomts can be earned almost anywhere (i.e., both within the Yahoo! 

network and outside), Yahoo! Points can only be redeemed at Yahoo's website. In another 
embodiment, Yahoo! Points can be redeemed at any Yahoo-authorized website - e.g., a 
website of a merchant that has some commercial relationship with Yahoo! or a third-party 
service bureau. These Yahoo-authorized merchants may be advertisers on Yahoo, merchants 
10 in the Yahoo! Shopping network, and other merchants with some contractual relationship with 
Yahoo. 

Yahoo! Points can be redeemed in one of two ways - (1) redemption for special gift 
certificates, and (2) redemption through the Yahoo! Auction System, Other forms of 
redemption are of course possible. 

15 One way to redeem Yahoo! Points is through a fixed point redemption system whereby 

special gift certificates are awarded. Here, users can redeem their points for special gift 
certificates to Yahoo! Stores at fixed point levels. For example, for 2000 points, the user may 
receive a $20-off gift certificate to FAO Schwartz's Yahoo! Store. For more points, the value 
of the gift certificate may be higher. 

20 Another way to redeem points is through the Yahoo! Auction System. In one 

embodiment, Yahoo! will set up certain special auctions where users can bid on special prizes 
with Yahoo! Points instead of cash. Only those users with the requisite account balance will 
be allowed to participate. In other embodiments, all users with any number of accumulated 
Yahoo! Points can participate. 

25 In another embodiment, individual users may auction off their goods for Yahoo! Points 

instead of cash. In this embodiment, the auction is not initiated by Yahoo! as a special auction; 
but rather, an individual seller (or even a corporate merchant) can specify that the auction 
accepts Yahoo! Points instead of cash. 
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In another embodiment, Yahoo! can charge users points for various services, such as 
customer service and news subscriptions. In still another embodiment, Yahoo! can deduct 
points from users who behave in ways that are not desirable to Yahoo!, For example, Yahoo! 
could deduct points for those users who leave the Yahoo! website for a competitor's website, 
5 However, this feature will be used with some care and discretion. 

In another embodiment, points could be redeemed offline, just as points could be 
earned offline, 

4.4 POLICIES AND ABUSE CONTROL 

Certain policies are implemented to minimize the potential for abuse. Because of their 
10 resemblance to money, Yahoo! Points inherently invite possible abuse. Typically, those who 
are cash-poor but time-rich are motivated to come up with schemes to "beat the system." 
Thus, in accordance with one embodiment of the present invention, several policies are 
implemented. 

One policy will cap the number of points that a user can accumulate over a given time 
15 period. Analogously, the system will also limit the number of points that can be issued over a 
given time period. Refer to the section below entitled "Controls on Outstanding Points," 

Another policy will expire points older than a certain date. In one embodiment of the 
present invention, Yahoo! Points expire one year from the end of the calendar quarter they are 
earned. Thus, points earned on February 15, 1997 expire on March 31, 1998. Similarly, 
20 points earned on January 1, 1997 also expire on March 31, 1998. In both cases, the end of the 
calendar quarter that the points are earned is March 31, 1997. In another embodiment, Yahoo! 
Points expire one year form the date they are earned. For example, points earned on February 
15, 1997 expire on February 15, 1998 in this latter embodiment. In some instances, however, 
expired points may be usable in some sweepstakes. In another embodiment, expiration is 
25 either not implemented at all or implemented in limited form. How limited? Merchants may 
indicate whether their points can expire or not. Also, the expiration may only apply to certain 
merchandise or certain ways of earning points. For example, points earned by clicking on an 
ad expire in one year, but points earned by registration do not expire at all. 



27 



SV/103327.01 
08142000/13:06/18568.1 



Another policy makes the points non-transferrable from one account to another. This 
policy will prevent users from simply creating multiple accounts and transferring them to a 
single deposit account. 

Earned points will also be held in "escrow" for some time period (e.g., 30 days) upon 
5 issuance in order to account for any returns of merchandise or disputed charges. This policy 
will not apply to some earned points such as "click-thru" ads, promotional trial memberships, 
and registrations. 

Certain awards can be checked to make sure that they are not being credited more than 
the requisite number of times for the same action. Thus, a banner ad, which offers one-time- 

10 only points for clicking on the ad, may appear on a website for all to see. If a user clicks on 
that ad, he will earn his points. When he returns to diat website, he will see that ad again. By 
click on the ad again, he should not be awarded points again since he earned them once already 
and this is a one-time-only promotion. Cookies may be used for this purpose. However, other 
embodiments will check the user's account instead. 

15 Points in the account are also encrypted to prevent unauthorized access to and/or 

modification of point totals in user accounts. 

4.5 CONTROLS ON OUTSTANDING POINTS 

Yahoo! Points will also be budgeted; that is, certain controls will be implemented to 
limit the number of points that are outstanding among the users. Yahoo! will also control the 

20 number of points issued over a given time period. Also, with the expiration date feature, 

Yahoo! can ensure that users will not accumulate large numbers of points indefinitely without 
redeeming them. Either the user will use up the points via redemption or the points will 
expire. In either case, the points will be removed from circulation. 

However, controlling the number of points that are outstanding is far from a trivial 

25 task. Enough Yahoo! Points will need to be created and issued to keep up with consumer 

behavior. Many consumers will make purchasing decisions and expect to earn some number of 
points. Other consumers make purchasing decisions for the sole purpose of earning points. 
Any negative deviation from this expected outcome will have negative consequences; that is, if 
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the consumer gets fewer points than he was expecting (or no points at all), the consumer will 
be dissatisfied and may no longer be so loyal to the merchant(s). 

Conversely, Yahoo! may also need to encourage the redemption of points to remove 
these points from circulation. One way to encourage the redemption of points is to increase 
5 the variety of merchandise available for auction. Along this line, a variation of this scheme is 
to increase the quality of the merchandise. Similarly, the variety of the merchandise should 
also be increased. In this way, the auction system offers merchandise that the consumer 
actually wants. Redeeming hard-earned points for merchandise that the consumer does not 
want or that the consumer grudgingly settles for will invariably create dissatisfaction and 

10 weaken whatever bond that the merchant has established with the consumer. 

Another way to encourage the redemption of points is to decrease the redemption 
thresholds so that more discount coupons is available for redemption at a faster rate. So, the 
user need not accumulate as many points as before to obtain that same discount coupon. The 
merchant must create the perception among the consumers that the requisite thresholds are 

15 achievable within a reasonable period of time. If the threshold levels are set so high that the 
only merchandise that the consumer believes he can win is a toaster, the consumer may not be 
motivated to be loyal to this merchant. Under this lose-lose scenario, this consumer would 
rather give up his points than to behave in ways to accumulate more points. 

A third way to encourage the redemption of points is to make the life span of the points 

20 shorter (expiration in 8 months instead of 1 year). Of course, this does not mean that Yahoo! 
will accelerate the expiration date; rather, the points will have a shorter life span at the time of 
issuance (e.g., expire hi 8 months from now instead of 1 year). However, if the life span is 
too short, consumers may not bother earning these points because of their belief that they may 
never be able to redeem them in time; that is, they believe, whether right or wrong, that they 

25 may not buy enough to earn the requisite threshold number of points to be able to redeem them 
before the points expire. 

Different classes of points can also be set up so that each class is associated with a 
different rules governing their expiration and value. The following is a list of the different 
classes of points that are offered in various embodiments of the present invention: 
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(1) Some points last one calendar year from the date of issuance, 

(2) Some points last for a shorter duration (i.e., less than one year) but may be easier to 
obtain, 

(3) Some points could be worth more to those consumers who already have a lot of 
points (e.g., the points could double in value if a particular consumer already has 
more than 100,000 points in his account), 

(4) Some points could be starter points, and be worthless to people who already have 
accounts set up, 

(5) Points could decay over time, with a half-life, much like Uranium, 

(6) Pomts could gain in value when traded within groups of friends, thus creating 
uicentives for communities of points holders to form, 

(7) Points could be limited in their quantity, creating collectible points that increase in 
value because of supply and demand, 

(8) Points could have a limited number of uses before they disappear. For example, a 
point could only work for three purchases, and then be worthless, disappearing 
from circulation, 

(9) A point could gain in value as it moves through the system, increasing in value after 
each transaction, 

(10) Points could have a random element built in, disappearing or increasing in value 
for no known reason, 

(11) Users could be given the ability to "invest" their points, either in the stock 
market or some other surrogate. Thus, when the chosen financial instrument 
increased in value, they'd be awarded more points, and if it decreased, they would 
lose points, 

(12) Users could donate their points to charity. A merchant (or Yahoo!) could tiien 
agree to transfer those points into a cash donation, 

(13) Users could use the points to vote in "elections" that are either polls or are 
actual town meetings to determine policies of a non-governmental nature. 
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Alternatively, users could donate their points to political candidates, who could use 
them to buy political advertising on Yahoo!, 

(14) Users could bid in auctions in which not only the winner has his points 
confiscated in exchange for the item being auctioned (the standard model), but in 
fact, some portion of the losers also lose their points (even though they receive 
nothing in exchange). While these auctions would certainly attract fewer bidders, 
the bidding would likely go up, 

(15) Users could use the points earned (without purchasing) to buy entries into 
sweepstakes or participate in online games of chance, 

In any event, the controls involve the appropriate combination of the above three 
schemes (i.e., increase inventory, decrease redemption thresholds, variable life span and value 
of points). In one embodunent, the large number of participating merchants will ensure that 
the supply of redeemable merchandise will be large enough, varied enough, and of sufficiently 
high quality to motivate consumers to redeem their points. If the redemption point thresholds 
are lowered, more consumers will believe that these thresholds are reachable and will behave 
in ways to accumulate more points for redemption. Finally, by shortening the life span of 
points, more consumers will redeem points sooner rather than later. 

4.6 POINT ISSUANCE BY OFFER SERVER 

Returning to FIG. 2, the database server 136 includes an offer server 139 therein whose 
primary function is to check and deliver points to users' accounts. The offer server 139 works 
with the database server 136 and the account database 134 to accomplish this purpose. In other 
embodiments, the offer server is identical to the database server. Also, in some embodiments, 
the web server performs the same tasks as the database server. 

The operation of the offer server 139 will now be discussed with respect to the flow 
chart of FIG. 3 and the server configuration of FIG. 2. The process starts at step 200. At step 
201, the user performs some point-actionable event such as viewing an advertisement, 
purchasing a product, or registering with a website. Of course, not all of these events are 
point-actionable, but usually the website will indicate that points can be earned by taking some 
kind of specified action. 
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At step 202, the database server associates an OfferlD and the user's YahooID with this 
event. In one embodiment, a unique OfferlD is associated with a given event. Let's say that 
clicking on an ad is an event which triggers the point issuance. This particular event is 
associated with the same OfferlD regardless of the users who click on it. Even if multiple 
5 users click on this ad, the same OfferlD is associated with this action for all the users. 

Similarly, if the same user clicks on the ad multiple times, the same OfferlD will associated 
with this action. 

The database server 136 then directs the user to the offer server 139 with this OfferlD 
and YahooID at step 203 in a manner that is relatively transparent to the user. The offer 

10 server 139 then checks the OfferlD and YahooID with the plurality of YahooIDs in the account 
database 134 at step 204. At step 205, the offer server 139 determines whether the user has an 
active account m the account database 134. If not, the offer server 139 informs the database 
server 136 of this fact. The database server 136 then alerts the user that no active account 
exists and requests that the user set up an account with Yahoo! at step 206. The database 

15 server 136 then shows the user the web page where the proper registration forms are found. If 
the user refuses to set up an account at step 207, the process terminates at step 213. If the user 
successftiUy sets up an account at step 207, the database server 136 proceeds to step 203 where 
the database server 136 directs the user to the offer server 139 again. 

Retummg to step 205, if the user has an active account with Yahoo, the offer server 

20 139 then checks if the award is valid at step 208. Usually, the award is valid and this step will 
merely serve as a precautionary step. Sometimes, a promotional award may have expired but 
the award advertisement may still be inadvertently left on the website. Other times, the 
merchant may have prematurely discontinued an award but the award advertisement may still 
be on a website. If the award is not valid at step 208, the offer server 139 indicates this fact to 

25 the database server 136 which then alerts the user at step 211. Step 212 is not applicable so 
the process then ends at step 213. 

If the award is valid at step 208, the offer server 139 checks if all award restrictions are 
satisfied at step 209. These restrictions may be dollar amount of the purchase, quantity of 
purchase, properly filling out a registration (with all required fields completed), and properly 
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viewing the advertisement (a mere click-through may not be enough in some cases). If the 
award restrictions are not satisfied at step 209, the offer server 139 indicates this fact to the 
database server 136 which then alerts the user at step 211. At step 212, the database server 
136 assists the user to rectify any deficiencies in the restrictions (if possible). If the user still 
5 does not satisfy the restrictions of the award at step 212, the offer server 139 proceeds to end 
the process at step 213. If the invalid condition detected at step 208 is not rectifiable for any 
reason, step 212 would resolve into "No/Not Applicable" and the proces ends at step 213. 

If the user satisfies the restrictions at step 212 or step 209, the offer server 139 
proceeds to step 210. At step 210, the offer server 139 awards the points to the user's account 
10 in the account database 134. The process then ends at step 213. 

In this embodiment, the database server 136 includes the offer server 139 therem. In 
other embodiments, the offer server 139 may be separate from the database server 136. In still 
further embodiments, the database server 136 performs all the functions that the offer server 
139 performs. 

15 In another embodiment, the steps 205-207 are accomplished before point issuance ever 

becomes an issue; that is, the user either logs into Yahoo's auction website with his respective 
YahooID or sets up an account at the time of login if the user has no account established yet. 
Thus, when the user accesses Yahoo's auction website (or some other Yahoo! shopping 
website), the system does not recognize the user either because the user does not have an 

20 account yet or has yet to log into his account. The standard interface of the system would then 
give the user the option of either logging into his account (if one already exists) or settmg up 
an account. 

5.0 MANAGEMENT TOOLS 

Returning to FIG. 2, the server contains a suite of management tools 153 inside the the 
25 database server 136. The management tools 153 also provide storage for web page 

information. The management tools 153 provide tools to manage various aspects of the 
Yahoo! Points program. 

The management tools 153 include an offer editor, a points program master editor, a 
coupon generator, and a customer care tool. The offer editor allows marketing/production 
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personnel to enter offer rules (e.g., dates, restrictions). Additionally, the offer editor allows 
these personnel to schedule "win/' "lose," and "ineligible" strmgs, which are the HTML 
strings served into pages like ads. However, these strings are exemplary. Other strings for 
different scenarios can be created. For example, Yahoo! can serve ads that are dependent on 
5 the number of points a user has accumulated so far. So, a user with 1000 points can get a 
particular ad. Yahoo! can also serve ads that are dependent on how close the user's 
accumulated points are to their expiration dates. So, if 500 points are about to expire in the 
next week, Yahoo! will show a particular ad. 

Moreover, the offer editor provides for the entry of point budgets. To test some of the 
10 features of the Yahoo! Auction System, the offer editor allows OfferlDs to be artificially 
created so that an actual point-actionable event need not be triggered. 

The points program master editor allows Yahoo! personnel to flexibly set numerical 
limits on point issuance. Thus, the editor can be used to set the maximum number of points 
per any given time frame (e.g., day, hour, week, month) that may be issued to any given user. 
15 This editor can also set expiration dates on a point by point basis. 

In another embodiment, a coupon generator is provided. The coupon generator is used 
to set up fixed point offers, such as $20-off coupon with a particular merchant in exchange for 
500 points. The coupon generator can set any number of points for any value coupon. 

The customer care tool allows Yahoo! persomel to view users' transaction histories, 
20 make account adjustments, and view prize auction results (including winners and specific 
prizes). 

6.0 AUCTION FORMATS 

A variety of different auction formats are offered for the buyers and sellers of the 
Yahoo! Auction System in accordance with one embodiment of the present invention. In the 
25 following discussion, each different auction format will be discussed with respect to the 
Yahoo! Point system and its implication to a user's respective account. 

6.1 STANDARD AUCTION 
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The auction foraiat known to most members of the general public is the Standard 
Auction format, where the Yahoo! Auction System awards the merchandise to the top bidder at 
the bid price after the auction has been active for the duration of its specified time period. 

In one embodiment, the standard auction applies to the case where a single item is up 
5 for bid for a specified time period. Typically, a starting bid price is offered by the auctioneer 
or Yahoo! Auction System based on pre-auction instructions from the seller. In one 
embodiment, the starting bid price is the absolute minimum price that the seller is willing to 
sell his merchandise. In other embodiments, the starting bid price is merely the starting point. 
In either case, the seller will normally inform the Yahoo! Auction System in advance of the 
10 minimum selling price for a given item, whether this minimum price is the starting bid price or 
some specific amount above the starting bid price. In other embodiments, the starting bid 
price and the minimum selling price are not provided and the seller is willing to accept ahnost 
any bid price for the merchandise for the start and conclusion of the auction. Havuig indicated 
the starting bid price for the merchandise, the Yahoo! Auction System will reject or refuse any 
15 bid that is under the specified startmg bid price. 

At this point, the seller may elect to lower his starting bid price to entice potential 
bidders to bid on this item or withdraw his item altogether. Typically, the seller will lower the 
starting bid price under the theory that as soon as one bid is offered, the Yahoo! Auction 
System will be flooded with other bids for that same item. Alternatively, the Yahoo! Auction 
20 System may automatically lower tiie starting bid price to a certain point (or series of points) 
based on pre-auction instructions from the seller if valid bids are not being received after an 
initial start-up period has elapsed. Thus, after an initial start-up period has elapsed, the 
starting bid price may be reduced from $200 to $190. If bids are still not received after a 
second initial start-up period, the Yahoo! Auction System may automatically reduce the 
25 starting bid price from $190 to $180. 

Depending on the pre-auction instructions by the seller, the starting bid price may be 
reduced any number of times for any number of initial start-up periods. This initial start-up 
period may be one day from the start of the auction for that particular item in accordance with 
one embodiment of the present invention. In other embodiments, the initial start-up period 
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may be more or less than one day depending on the popularity of the merchandise. For 
popular and hot-selling merchandise, the initial start-up period may be only a few hours to 
minutes from the start of the auction. For less popular merchandise, the initial start-up period 
may be several days to weeks. The Yahoo! Auction System of the present invention can 
5 accommodate any number of initial start-up periods, any initial start-up period values, any 
amount for the starting bid price, and any increment for the reduced starting bid price that the 
seller specifies before the start of the auction for a given item. 

In order for a bid to be accepted, the bid must be valid. In one embodiment, a bid is 
valid if the bidder is properly registered, the bid amount is proper, the item amount must be 

10 supported by the inventory, and the bid was submitted within a specified time period. In each 
of these cases, if an invalid bid has been received, the Yahoo! Auction System will attempt to 
rectify the situation by alerting the bidder of the invalidity of the bid and suggesting possible 
courses of action that the bidder can take to make the bid valid. 

With respect to die registration, the Yahoo! Auction System may require all potential 

15 bidders to register with some basic information such as name, age, address, phone number, 
and some billing information such as a credit card number. This registration ensures that only 
authorized people will participate in the Yahoo! Auction System. Also, the registration 
ensures that a user account will be set up in the database so that if particular payment units 
(e.g., incentive points, cash) are used during the bidding process, appropriate checks can be 

20 made to ensure that he either has enough payment units in his account or is otherwise credit 
worthy if his bid exceeds his account balance. If a bidder is not registered, the Yahoo! 
Auction System will alert the bidder of this fact and suggest that the bidder register. The 
registration process is relatively straightforward and quick. 

In another embodiment, the potential bidder need not register with the Yahoo! Auction 

25 System directly. Instead, he may register with any number of other merchants who are 
associated with the Yahoo! Auction System somehow including, but not limited to: (1) the 
merchant has an agreement with the owners of the Yahoo! Auction System, (2) the merchant is 
allowed to advertise on the Yahoo! Auction System's website, (3) the Yahoo! Auction 
System's website has provided a link to the merchant's website, (4) the merchant offers points 
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that are recognized by the Yahoo! Auction System, and (5) the Yahoo! Auction System awards 
points that can be redeemed at the merchant's website. 

With respect to the proper bid amount, the Yahoo! Auction System requires a bid that 
satisfies an absolute minimum amoimt and minimum increment. The absolute minimum 
5 amount is typically the starting bid price. So, if the starting bid price is $400, a bid of $350 is 
not valid. Also, the Yahoo! Auction System requires subsequent bids to satisfy some 
prescribed increment. This increment may vary from one item to another and from one bid 
phase to another. For example, if the required minimum increment for a bicycle is $5 and the 
current high bid is $600, a valid higher bid must be at least $605. So, if the bid $603, the bid 

10 is not valid. Also, if the bid is $599, the bid is not valid. Conversely, if the bid is $606, the 
bid is valid because the minimxmi bid increment of $5 has been satisfied. For both the bid 
amount and bid increment, the Yahoo! Auction System will alert the bidder if neither is 
satisfied and suggest possible amounts. For bid amounts, the Yahoo! Auction System will 
suggest the starting bid price if the auction has just commenced or no bid has been received. 

15 For the bid increment, the Yahoo! Auction System will alert the bidder of the correct bid 
increment and suggest a bid price by adding the valid bid increment to the current high bid. 

In accordance with another embodiment of the present invention, the minimum bid 
increment may also vary for an auction session for a given item. In particular, an auction 
session may be divided into distinct phases - a first initial start-up phase, a middle phase, and 

20 an end game phase. During each of these phases, the required minimum bid increment may be 
different. The initial start-up phase and end game phase may allow a modicum amount for the 
increment, while the middle phase may require substantially larger increments. 

The quantity of the items must also be supported by the inventory in order for the bid to 
be valid. If N items are being auctioned, a bid on N+1 items is not valid because the 

25 inventory of N items cannot support N+1 items. Similarly, if N items are being auctioned off 
but during the course of the auction, M items (where M < N) have already been awarded to a 
bidder, a subsequent bid for N items is not valid because only N-M items are remaining. If a 
bid is invalid because the quantity requested cannot be supported by the inventory, the Yahoo! 
Auction System will alert the bidder of this state and ask the bidder for a lower quantity. The 

37 

SV/103327.01 
08142000/13:06/18568.1 



Yahoo! Auction System may also suggest the lower quantity that can actually be supported by 
the current inventory. For single item cases, though, the item quantity requirement should be 
easily satisfied because either that single item is available (no high bidder yet) or not available 
(winning bidder has been determined and auction is closed). 
5 Finally, the bid must be received by the Yahoo! Auction System within the specified 

time period for the auction in order for the bid to be valid. For any given auction session, the 
seller offers his merchandise for only a specific time period (e.g., 24 hours). The auction 
opens (i.e., starts) at some beginning time and closes (i.e., ends) at some specific future time. 
This time period will vary from one item to another and from one seller to another. Any bid 
10 that is otherwise valid (i.e., proper bid amount, proper bid increment, properly registered 
bidder) that is received within the time period for the auction remains valid. If the bid is 
received after the specified time period has expired, the bid is not valid. When a bid is 
received by the Yahoo! Auction System, the bid is time stamped so that it can be properly 
processed. 

15 The winner of the auction is the bidder with the highest valid bid among all the other 

valid bids within the time period specified for the auction. The winning bidder must then 
purchase the item he won at the winning bid price from the seller. The Yahoo! Auction 
System in effect matches up the buyer and the seller for the offered item. For the seller, this 
buyer is the best buyer because this buyer has offered the highest price for that particular 

20 desired item. For the buyer, this seller is the best seller because he was able to purchase 

(theoretically) from the seller that particular desired item at a price that is lower than its retail 
value. Of course, if no one bids on this item at the starting bid price during the entire auction 
time period specified for this item, the auction ceases with no winners. The Yahoo! Auction 
System may then automatically lower the starting bid price (in accordance with pre-auction 

25 instructions from the seller) to entice bid submission. On the other hand, the seller may not 
want to lower the starting bid price and not offer this item for auction. 

In a variation of this time-based Yahoo! Auction System, another embodiment requires 
that the merchandise be awarded immediately to the bidder who bids some amount that is at or 
above a sell-off threshold. Refer to the "Buy-or-Bid" Auction format described further below. 
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Alternatively, the merchandise is sold at the highest bid price when the time period for the 
auction expires. This sell-off threshold may or may not be disclosed to the potential bidders. 
Thus, if the seller wants to sell a particular item when the bid price reaches $500, the first 
bidder to bid $500 (or more) will be awarded the item regardless of whether another bidder 
5 may outbid this bidder. On the other hand, if none of the bids reaches the magic $500 
threshold, the highest bidder after the auction time period expires will win the contest. 

A particular implementation of the Yahoo! Auction System and how it implicates the 
users' respective accounts will now be described with respect to FIG. 4. The auction begins at 
step 160. 

10 At step 161, the Yahoo! Auction System offers item X at starting bid price P with a 

minimum increment dP in accordance with the seller's pre-auction instructions. At step 162, 
the Yahoo! Auction System waits for or inquires about any new bid(s). If no new bid is 
forthcoming, the Yahoo! Auction System proceeds to step 167, which checks for any auction 
termination condition. Auction termination conditions are discussed in greater detail below and 

15 include such conditions as expiration of a predetermined time period for the auction (e.g,, 72 
hours) and premature closing due to inactivity within any specified time period. If any of these 
auction termination conditions is present, the auction terminates at step 170; otherwise, the 
Yahoo! Auction System returns to step 162 to check for any new bids. 

If a new bid is received, such as BID^ew hy a new bidder (whoever this may be) at step 

20 163, the Yahoo! Auction System checks for the validity of BID^ew at step 164. If this is the 
very first bid, checking validity means that BID^ew must be at least the starting bid price P. If 
this bid is an attempt to outbid an already existing high bid, the new bid BID^jgw n^ust be at 
least the sum of the current high bid and the minimum bid increment dP. Other validity checks 
are described elsewhere in this patent specification. If BID^ew is not valid, the Yahoo! Auction 

25 System returns to step 162 where it checks for other new bids. 

If BIDnew is valid, the Yahoo! Auction System proceeds to step 165 where it checks the 
new bidder's account to determine if BID^ew points are available. This ensures that the new 
bidder is bidding with points that he has so that if he ultimately wins the auction, the seller of 
the item X can be paid. Also, this step 165 is performed after step 164 so that if the bid is 
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invalid at step 164, the Yahoo! Auction System need not spend additional time and resources to 
check the new bidder's account in the account database. On the other hand, other 
embodiments of the present invention require the system to check the new bidder's account 
before the validity check. If BID^ew is not available in the new bidder's account at step 165, 
5 the Yahoo! Auction System returns to step 162 where it checks for new bids. 

If BIDnew is available in the new bidder's account at step 165, the Yahoo! Auction 
System proceeds to step 166. Here, the system reserves BID^ew the new bidder's account 
so that this reserved amount of pomts can not be used for other transactions. If BID^ew was 
submitted to outbid an already existing high bid, then the previously reserved high bid amount 

10 is unreserved in the previous high bidder's account. At this point, the new bidder is the 
current high bidder with the current high bid at BID^ew 

In other embodiments, step 166 does not unreserve any bids until after the auction 
closes. This is done as a precaution in case a winning bidder backs out. Because other bids 
are reserved, the bidders associated with these bids may be the ultimate winner in those 

15 infrequent occasions when a winning bidder changes his mind. In another embodiment, the 
Yahoo! Auction System prevents bidders from backing out since Yahoo! has control of his 
account. 

The system then proceeds to step 167 where it checks for the presence of any auction 
termination condition. If no auction termination condition is present, the system returns to step 

20 162 where it checks for new bids. If new bids are received, the system proceeds down the 
flowchart as described above. Note that in this embodiment, the system will always reserve 
the new high bid in the new high bidder's account while unreserving the previous high bid 
(now losing bid) in the previous high bidder's account. If any auction termination condition is 
present, the auction ends at step 170. 

25 At this point, the Yahoo! Auction System actually deducts the reserved amount (or the 

winning bid amount if the winning bid amount is different from the reserved amount) from 
each winner's account. Also, the other reserved amounts of non-winners (if any) are 
unreserved in their respective accounts, if this had not been done already. Some embodiments 
unreserve prior to auction close and other embodiments unreserve after the auction closes. 
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The Standard Auction format also applies to multiple items and multiple winners. 
Whenever a seller has multiple quantities of the same item that he wants to auction, such as 
twenty light bulbs of the same brand from company X, the seller need not auction them off 
separately. Instead, the seller may auction these identical and otherwise commodity items 
5 together. Of course, the seller will normally not sell non-conmiodity items together, such as 
multiple rare baseball cards whose respective value depends on the baseball player profiled, the 
year of the card, the rarity of die card, and the physical condition of the card. 

In the multiple item/multiple winner variation of the Standard Auction format, if N 
items are auctioned off, the Yahoo! Auction System will award these N items to N different 

10 winning bidders at each winning bidder's bid price. For example, if ten items are being 
auctioned off and ten different bidders are the highest bidders, each item is awarded to each 
bidder at each bidder's respective bid prices. Thus, for the same item, different bidders may 
ultimately be awarded the item at different prices. 

A particular implementation of the Yahoo! Auction System for the Standard Auction 

15 format for multiple items and how it implicates the users' respective accounts will now be 
described with respect to FIG, 5. The auction begins at step 180, 

At step 181, the Yahoo! Auction System offers N items (i.e,, commodity identical 
items) at starting bid price P each with a minimum increment dP in accordance with the seller's 
pre-auction instructions. For the auction of multiple items, these N items will be awarded to 

20 the top N bidders at then* respective top N bids. At step 182, the Yahoo! Auction System 

waits for or inquires about any new bid(s). If no new bid is forthcoming, the Yahoo! Auction 
System proceeds to step 188, which checks for any auction termination condition (as discussed 
above). If any auction termination condition is present, the auction terminates at step 189; 
otherwise, the Yahoo! Auction System returns to step 182 to check for any new bids. 

25 If a new bid is received, such as BIDnew by a new bidder (whoever this may be) at step 

183, the Yahoo! Auction System checks for the validity of BID^ew at step 184. If this is the 
very first bid, checking validity means that BID^ew be at least the starting bid price P. If 
this bid is an attempt to outbid an already existing high bid or be included among the top N 
bids, the new bid BID^ew ^nust be at least the sum of the current high bid and the minimum bid 
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increment dP. Other validity checks are described elsewhere in this patent specification. If 
BIDnew is not valid, the Yahoo! Auction System returns to step 182 where it checks for other 
new bids. 

If BIDnew is valid, the Yahoo! Auction System proceeds to step 185 where it checks the 
5 new bidder's account to determine if BID^ew points are available. This ensures that the new 
bidder is bidding with points that he has so that if he is ultimately named as one of the top N 
bidders for this auction, the seller of the N items can be paid. If BID^ew is not available in the 
new bidder's account at step 185, the Yahoo! Auction System returns to step 182 where it 
checks for new bids. 

10 If BIDj^Ew is available in the new bidder's account at step 185, the Yahoo! Auction 

System proceeds to step 186. Here, the system reserves BID^ew i^i the new bidder's account 
so that this reserved amount of points can not be used for other transactions. If BID^ew 
displaces an already existing bid from the top N bid positions, then the displaced bid amount is 
unreserved in the displaced bidder's account at step 187. At this point, the new bidder is 

15 among the top N bidders with his bid at BID^ew. 

In other embodiments, step 187 does not unreserve any bids until after the auction 
closes. This is done as a precaution in case a winning bidder backs out. Because other bids 
continue to be reserved, the bidder(s) associated with these bids may be the ultimate winner(s) 
in those infrequent occasions when a winning bidder changes his mind. In another 

20 embodiment, the Yahoo! Auction System prevents bidders from backing out since Yahoo! has 
control of his account. 

The system then proceeds to step 188 where it checks for the presence of any auction 
termination condition. If no auction termination condition is present, the system returns to step 
182 where it checks for new bids. If new bids are received, the system proceeds down the 

25 flowchart as described above. Note that in this embodiment, the system will always reserve 
the top N bids in the top N bidders' respective accounts while unreserving any displaced bids 
in the displaced bidders' respective accounts. If any auction termmation condition is present, 
the auction ends at step 189. 
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At this point, the Yahoo! Auction System actually deducts the reserved amount (or the 
winning bid amount if the winning bid amount is different from the reserved amount) from 
each winner's account. Also, the other reserved amounts of non-winners (if any) are 
unreserved in their respective accounts, if this had not been done already. Some embodiments 
5 unreserve prior to auction close and other embodiments unreserve after the auction closes. 

In another variation of the multiple item/multiple winner Standard Auction format, a 
1:1 mapping of items to winners is not strictly required; that is, the bidders may bid on more 
than one item and different winning bidders will generally pay different prices for the items. 
One bidder may potentially win all N items, but typically, a plurality of bidders may win any 

10 combination of these N items. For example, for two top bidders for ten auction items, one 
bidder may win seven items and the other bidder may win three items. Obviously, if ten items 
are being auctioned, the Yahoo! Auction System will not allow more than ten bidders to win. 
Other variations on the multiple item/multiple winners format will be described further below. 
6.2 DUTCH AUCTION 

15 Another auction format is known as Dutch Auction , The Dutch Auction format also 

involves the auctioning of multiple items to multiple successful bidders. In contrast to the 
Standard Auction format, however, the Dutch Auction format awards the plurality of items to 
the top bidders at the price (per unit) bid by the lowest successful bidder. Not only do all the 
winning bidders pay the same price for items but at the lowest bid price among the winning 

20 bidders. Thus, a successful bidder is not necessarily "penalized" for bidding too high since 
this bidder will eventually pay for the item(s) at the price bid by the lowest successful bidder. 
For example, assume that five items are being auctioned off and the top five bidders at the 
conclusion of the auction time period bid $70, $67, $66, $61, and $60, respectively. Instead 
of each successful bidder paying for the item at their respective bid price, all of the five top 

25 bidders will be awarded the items for $60 each, which is the lowest of the bids among the top 
bidders. 

Two embodunents of the Dutch Auction system as implemented within the Yahoo! 
Auction System will now be discussed. The primary difference between the two embodiments 
is the bid that is reserved for the top bidders. In the first embodiment, the lowest bid among 
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the top N bidders is determined after the reception of each valid bid and reserved in the top N 
bidders' respective accounts. In the second embodunent, the respective bids of the top N 
bidders are reserved in the bidders' respective accounts and, upon completion of the auction, 
the necessary adjustments to the accounts are made so that all the top bidders pay only the 
5 lowest bid among the top bids. 

The first embodiment of the Dutch Auction format in the Yahoo! Auction System and 
how it implicates the users' respective accounts will now be described with respect to FIG. 6. 
The auction begins at step 210. 

At step 211, the Yahoo! Auction System offers N items at starting bid price P each with 

10 a minimum increment dP in accordance with the seller's pre-auction instructions. For the 
auction of multiple items, these N items will be awarded to the top N bidders at the bid price 
of die lowest bid among the top N bidders. At step 212, the Yahoo! Auction System waits for 
or inquires about any new bid(s). If no new bid is forthcoming, the Yahoo! Auction System 
proceeds to step 222, which checks for any auction termination condition (as discussed above). 

15 If any auction termination condition is present, the auction terminates at step 223; otherwise, 
the Yahoo! Auction System returns to step 212 to check for any new bids. 

If a new bid is received, such as BID^ew by a new bidder (whoever this may be) at step 
213, the Yahoo! Auction System checks for the validity of BIDj^^ew step 214. If this is the 
very first bid, checking validity means that BIDj^ew "i^st be at least the starting bid price P. If 

20 this bid is an attempt to outbid an already existing high bid or be included among the top N 
bids, the new bid BID^ew ^^^^ t)e at least the sum of the current high bid and the minimum bid 
increment dP. Other validity checks are described elsewhere in this patent specification. If 
BID^Ew is not valid, the Yahoo! Auction System returns to step 212 where it checks for other 
new bids. 

25 If BIDnew is valid, the Yahoo! Auction System proceeds to step 215 where it 

determines BIDf^u^, which is the lowest bid among the top N bids. If the auction were to end 
now, all of the top N bidders pays the same bid price BIDj^hn- At step 216, the system checks 
the new bidder's account to determine if BID^in points are available. This ensures that the 
new bidder has enough points in his account so that if he is ultimately named as one of the top 
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N bidders for this auction, the seller of the N items can be paid at BIDj^us, points per item. If 
BID^^iN is not available in the new bidder's account at step 216, the Yahoo! Auction System 
proceeds to step 217 so that BID^in reverts back to the previous value since the new bidder 
will not be among the top N bidders. The system then returns to step 212 where it checks for 
5 new bids. 

If BIDmin is available in the new bidder's account at step 216, the Yahoo! Auction 
System proceeds to step 218. Here, the system reserves BID^jj^ in the new bidder's account so 
that this reserved amount of points can not be used for other transactions. The new bidder's 
bid BIDnew is also associated with the new bidder and stored for two purposes: (1) BID^,ev/ is 

10 used to determine the top N bidders, and (2) if BID^ew is the lowest bid among the top N 

bidders, all winners pay for the items at the bid price BIDj^evv, Note that by reserving BID^if^ 
instead of BID^ew this embodiment, the Yahoo! Auction System allows bidders to bid on 
items with points (i.e., BIDf^E^) that they may not have in their accounts because they have just 
enough points (i.e., BID^in) to be among the top N bidders. 

15 At step 219, the system checks if BID^ji^^ is available in the other bidders' respective 

accounts. Because the new bidder is now one of the top N bidders, it has more than likely 
displaced another bidder who was among the top N bidders. As a result of this displacement, 
the lowest bid among the top N bidders may have changed, usually with an increase in the bid. 
This new increase in the bid price may or may not be affordable to some of the top N bidders. 

20 Thus, this check at step 219 ensures that the other top bidders can pay for the items if the 
auction were to end now. 

If any of the top N bidders cannot afford BID^in, the system proceeds to step 220. The 
bidders whose account cannot support the new lowest bid BIDj^i^^ among the group is removed 
from the list of top N bidders along with their respective bids. Their respective bids are 

25 unreserved. In other embodiments, step 220 does not unreserve any bids until after the auction 
closes. This is done as a precaution in case a winning bidder backs out. Because other bids 
continue to be reserved, the bidder(s) associated with these bids may be the ultimate winner(s) 
in those infrequent occasions when a winning bidder changes his mind. In another 
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embodiment, the Yahoo! Auction System prevents bidders from backing out since Yahoo! has 
control of his account. 

For the remaining bidders, BID^in is reserved in their respective accounts. This does 
not mean that an additional BID^^^ amount of points will be reserved; rather, differentials will 
5 be processed so that the total number of points reserved in each account for this particular 
auction will be BIDi^i^* For example, if a bidder had 5 points reserved in his account but the 
new BIDmjn is now 8 points, the system will now reserve 3 more points from this bidder's 
account so that the total number of points reserved is 8 points, or the new BIDj^i^. The system 
then proceeds to step 212 to check for any new bids. 
10 If all of the remaining bidders have enough points in their respective accounts to 

support BID^5iN> the system reserves BID^in in their respective accounts at step 221 by 
processing differentials as described above. The system then proceeds to step 222, which 
checks for any auction termination condition (as discussed above). If any auction termination 
condition is present, the auction terminates at step 223; otherwise, the Yahoo! Auction System 
^"Z 15 returns to step 212 to check for any new bids. 

W At the conclusion of the auction, the Yahoo! Auction System actually deducts the 

reserved amount (or the winning bid amount if the winning bid amount is different from the 

m reserved amount) from each wmner's account. Also, the other reserved amounts of non- 

^'"Z winners (if any) are unreserved in their respective accounts, if this had not been done already. 

i:3 20 Some embodiments unreserve prior to auction close and odier embodiments unreserve after the 
auction closes. 

Note that in this embodiment, the Yahoo! Auction System reserves the lowest bid 
among the top N bids in each of the top N bidders' respective accounts, rather than the 
bidders' respective bids. For example, bidder A bids 66 points to secure his position among 
25 the top 5 bidders for the 5 items that are being auctioned off. As a result, the top 5 bids are 55 
points (bidder B), 57 points (bidder C), 60 points (bidder D), 65 points (bidder E), and 66 
points (bidder A), However, despite his bid of 66 points, the system actually reserves only 55 
points in his account smce this Dutch Auction format awards the 5 items to the top 5 bidders at 
the lowest bid among the top 5 bids. 
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The second embodiment of the Dutch Auction format in the Yahoo! Auction System 
will now be described with respect to FIG. 7. The auction begins at step 225. 

At step 230, the Yahoo! Auction System offers N items at starting bid price P each with 
a minimum increment dP in accordance with the seller's pre-auction instructions. For the 
5 auction of multiple items in accordance with the Dutch Auction format, these N items will be 
awarded to the top N bidders at the bid price of the lowest bid among the top N bidders. At 
step 231, the Yahoo! Auction System waits for or inquires about any new bid(s). If no new 
bid is forthcoming, the Yahoo! Auction System proceeds to step 237, which checks for any 
auction termination condition (as discussed above). If any auction termination condition is 

10 present, the auction proceeds to step 238; otherwise, the Yahoo! Auction System returns to 
step 231 to check for any new bids. 

If a new bid is received, such as BID^ew by a new bidder (whoever this may be) at step 
232, the Yahoo! Auction System checks for the validity of BIDj^ew step 233. If BID^ew is not 
valid, the Yahoo! Auction System returns to step 231 where it checks for other new bids. 

15 If BIDnew is valid, the Yahoo! Auction System proceeds to step 234 where it checks the 

new bidder's account to determine if BID^ew points are available. This ensures that the new 
bidder has enough points in his account so that if he is ultimately named as one of the top N 
bidders for this auction and his bid BIDnew is the lowest bid among the top N bidders, the 
seller of the N items can be paid at BID^ew points per item from this new bidder. If BID^ew is 

20 not available in the new bidder's account at step 234, the Yahoo! Auction System returns to 
step 231 where it checks for new bids. 

If BIDnew is available in the new bidder's account at step 234, the Yahoo! Auction 
System proceeds to step 235. Here, the system reserves BID^ew i^i the new bidder's account 
so that this reserved amount of points can not be used for other transactions. 

25 Because the new bidder is now one of the top N bidders, it has more than likely 

displaced another bidder who was among the top N bidders. At step 236, the system 
unreserves the bid of any bidder who was displaced by the new bidder and the new bid 
BIDj^EW' III other embodiments, step 236 does not unreserve any bids until after the auction 
closes. This is done as a precaution in case a winning bidder backs out. Because other bids 
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continue to be reserved, the bidder(s) associated with these bids may be the ultimate winner(s) 
in those infrequent occasions when a winning bidder changes his mind. In another 
embodiment, the Yahoo! Auction System prevents bidders from backing out since Yahoo! has 
control of his account. 

5 The system then proceeds to step 237, which checks for any auction termination 

condition (as discussed above). If any auction termination condition is present, the system 
proceeds to step 238; otherwise, the Yahoo! Auction System returns to step 231 to check for 
any new bids. 

At the conclusion of the auction, the Yahoo! Auction System actually deducts the 
10 reserved amount (or the winning bid amount if the winning bid amount is different from the 
reserved amount) from each winner's account. Also, the other reserved amounts of non- 
winners (if any) are unreserved in their respective accounts, if this had not been done already. 
Some embodiments unreserve prior to auction close and other embodiments imreserve after the 
auction closes. 

15 Since an auction termination condition is present at step 237, the system proceeds to 

process the accounts of the top N bidders. Remember, in this embodiment, the system 
reserved the bidders' respective bids in their respective accounts. Because the Dutch Auction 
format awards the auction items to the top N bidders at the lowest bid price among the top N 
bids, some adjustments to the accounts have to be made. At step 238, the system adjusts the 

20 reservation amount in each of the top N bidders' accounts so only only the lowest bid amount 
among the top N bids is reserved in each account. Unlike the first embodiment, this 
embodiment reserves each bidder's bid instead of the lowest bid among the top N bids during 
the bidding process. At the conclusion of the auction, the adjustment is then made. The 
auction ends at step 239. 

25 6.3 PROGRESSIVE AUCTION 

Another auction format is known as Progressive Auction . The Progressive Auction is 
similar to the Dutch Auction format except ±at tiie 1:1 mapping of items to winners is not 
required. Instead, the multiple items can be divided up any way possible. In the Progressive 
Auction format, the Yahoo! Auction System awards the item(s) to the top bidders at different 
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prices based on the quantity of items bid; that is, the price that the top bidders have to pay for 
the item or items being auctioned is based on the lowest successful bid price for the given item 
quantity. For example, for twenty items, assume that three bidders are successful for four 
items each, and four bidders are successful for two items each. The three bidders who each 
5 won four items successfully bid $50, $55, and $58. Thus, the three bidders pay for their 
respective lot of four items at the lowest successful bid price for this group ~ $50 each. The 
four bidders who each won two items successfully bid $40, $42, $45, and $48. Thus, these 
four bidders pay for their respective lot of two items each at the lowest successful bid price for 
this group ~ $40 each. 

10 In the same example, if the top bidders all bid for only one item, the Yahoo! Auction 

System will have twenty successful bidders and each bidder will pay the lowest successful bid 
price, not the price that he bid. In this case, the Progressive Auction format reduces to the 
Dutch Auction format where the quantity of items awarded is the same for the entire inventory 
of such items. 

15 One embodiment of the Progressive Auction format in the Yahoo! Auction System and 

how it implicates the users' respective accounts will now be described with respect to FIG. 8. 
The auction begins at step 240, 

At step 241, the Yahoo! Auction System offers N items at starting bid price P each with 
a minimum increment dP in accordance with the seller's pre-auction instructions. For the 

20 auction of muhiple items, these N items will be awarded to the top bidders at the bid price of 
the lowest bid among the bidders within its group, where the bidders are grouped together 
based on the quantity of items bid. At step 242, the Yahoo! Auction System waits for or 
inquires about any new bid(s). If no new bid is forthcoming, the Yahoo! Auction System 
proceeds to step 252, which checks for any auction termination condition (as discussed above). 

25 If any auction termination condition is present, the auction terminates at step 253; otherwise, 
the Yahoo! Auction System returns to step 242 to check for any new bids. 

If a new bid is received, such as BID^ew points for each of K items by a new bidder 
(whoever this may be) at step 243, the Yahoo! Auction System checks for the validity of 
BIDnew at step 214. In one embodiment, the various quantities available are fixed by the 
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auction system. For example, if 10 total items are available, the system may only permit 
bidding on 4 items, 3 items, 2 items, and 1 item. In another embodiment, the quantity is not 
fixed and the bidder may bid whatever quantity he desires. 

Also, as more bidders submit bids, the auction system will need to resolve ties between 
5 a bidder who has bid a certain per unit price PI for Kl items and another bidder who bid a 
certain per unit price P2 for K2 items when the supply for the items cannot support both 
bidders. Several scenarios may be possible: 
P1=P2; K1=K2 

In this scenario, the bid price and the quantities are identical. One embodiment of the 
10 invention will favor the bid that came in first. 
P1=P2; K1>K2 

In this scenario, the bid prices are identical but the quantities are different (Kl >K2). 
In one embodiment, the system will favor the bidder with the higher quantity (i.e., Kl). In 
another embodiment, the system will favor the bid that came in first. 
15 P1>P2;K1=K2 

In this scenario, the quantities are identical but the bid prices are different (PI >P2). 
This scenario is essentially the classic auction model and the system will favor the higher bid 
price (i.e., PI). 
P1>P2; K1>K2 

20 In this scenario, both the quantities and the bid prices are different. Note also that one 

bidder's price (PI) and item quantity (Kl) are each greater than that for the other bidder. This 
is the also an easy conflict to resolve. The system will favor the higher bidder with the higher 
item quantity. 
P1>P2; KKK2 

25 In this scenario, both the quantities and the bid prices are different. Note that in this 

scenario, although one bidder's bid price (PI) is greater than the other bidder's bid price (P2), 
the higher bidder's item quantity (Kl) is less than the lower bidder's item quantity (K2). This 
is the most difficult scenario to resolve. In one embodiment, the system favors the bidder with 
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the greater bid price (PI) to maximize his potential profits. In another embodiment, the system 
favors the bidder with the greater quantity (K2) to encourage volume sales. 

For the purposes of illustrating this invention, however, the flowchart of FIG. 8 will 
show the fixed quantity embodiment. The flowchart of FIG. 8 will also not examine the 
5 different price-quantity scenarios (i.e., PI vs. P2; Kl vs. K2) to facilitate a clearer 
presentation of the accountuig aspect of the invention. 

Returning to step 244, the system checks the validity of BID^jew and item quantity K. If 
this is the very first bid, checking validity means that BIDj^e^ must be at least the starting bid 
price P. If this bid is an attempt to outbid an already existing high bid or be included among 

10 the top bids, the new bid BIDj^ew ^^st be at least the sum of the current high bid and the 
minimum bid increment dP. Of course, the item quantity K must not exceed the supply N, 
For example, if 10 items are available and two bidders bid for 4 items each, a third bidder 
cannot bid for 3 items because only 2 items are remaining. Other validity checks are described 
elsewhere in this patent specification. If either BIDj^je^ or K is not valid, the Yahoo! Auction 

15 System returns to step 242 where it checks for other new bids. 

If BIDnew and K are valid, the Yahoo! Auction System proceeds to step 245 where it 
determines BID^inCK), which is the lowest bid among those top bids associated with quantity 
K. The indexing of bids by bid quantity facilitates the formation of groups, which then allows 
the system to compare bids within a group. 

20 At step 246, the system checks die new bidder's account to determine if the product 

(BIDmii^(K))*K points are available. This ensures that the new bidder has enough points in his 
account so that if he is ultimately named as one of the top bidders in his group for this auction, 
the seller of the N items can be paid at BID^jnCK) points per item. If (BIDi^in(K))*K is not 
available in the new bidder's account at step 246, the Yahoo! Auction System proceeds to step 

25 277 so that BID^inCK) reverts back to the previous value since the new bidder will not be 
among the top N bidders. The system then returns to step 242 where it checks for new bids. 

If (BIDj^in(K))*K points are available in the new bidder's account at step 246, the 
Yahoo! Auction System proceeds to step 248. Here, the system reserves (BIDj^ijsj(K))*K points 
in the new bidder's account so that this reserved amount of points can not be used for other 
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transactions. The new bidder's bid BID^ewCK) is also associated with the new bidder and 
stored for two purposes: (1) BIDnew(K) is used to determine the top bidders in its group, and 
(2) if BIDnew(K) is the lowest bid among the top bidders in its group, all winners pay for the 
items at the bid price BID,^ew(K). Note that by reserving BIDmin(K) instead of BIDj^ewCK) in 
5 this embodiment, the Yahoo! Auction System allows bidders to bid on items with points (i.e., 
BIDnew(K)) that they may not have in their accounts because they have just enough points (i.e. , 
BIDi^in(K)) to be among the top bidders in their respective groups. 

At step 249, the system checks if (BIDmin(K))*K is available in the other bidders' 
respective accounts. Because the new bidder is now one of the top bidders, it may have 

10 displaced another bidder who was among the top bidders if the supply is limited (i.e. , the 
auction system can only have so many top bidders for the N items). If a displacement has 
occurred or the new bidder has just been added to the group with the lowest bid in that group, 
the lowest bid among the top bidders has probably changed. This new bid price in the group 
may or may not be affordable to some of the top bidders, especially if the bid price increased. 

15 Thus, this check at step 249 ensures that the other top bidders can pay for the items if the 
auction were to end now. 

If any of the top bidders in their respective group cannot afford (BIDf^,^(K))*K points, 
the system proceeds to step 250. The bidder(s) whose account cannot support the new lowest 
bid (BIDmin(K))*K within the respective group is removed from the list of top N bidders along 

20 with their respective bids. In these cases, the previously reserved amounts are now 

unreserved. In other embodiments, previously reserved bids are not unreserved until after the 
auction closes. This is done as a precaution in case a winning bidder backs out. Because other 
bids continue to be reserved, the bidder(s) associated with these bids may be the ultimate 
winner(s) in those infrequent occasions when a winning bidder changes his mind. In another 

25 embodiment, the Yahoo! Auction System prevents bidders from backing out since Yahoo! has 
control of his account. 

For the remaining bidders, (BIDmin(K))*K is reserved in their respective accounts. If 
the auction were to end now, the top bidders in the different groups pay the same per unit bid 
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price BIDmin(K) that is associated with their respective group. The system then proceeds to 
step 242 to check for any new bids. 

If all of the remaining bidders have enough points in their respective accounts to 
support (BIDj^in(K))*K points at step 249, the system reserves (BIDmin(K))*K points in their 
5 respective accounts at step 251 by processing differentials as described above. The system 
then proceeds to step 252, which checks for any auction termination condition (as discussed 
above). If any auction termination condition is present, the auction terminates at step 253; 
otherwise, the Yahoo! Auction System returns to step 242 to check for any new bids. 

At the conclusion of the auction, the Yahoo! Auction System actually deducts the 
10 reserved amount (or the winnmg bid amount if the winning bid amount is different from the 
reserved amount) from each winner's account. Also, the other reserved amounts of non- 
winners (if any) are unreserved in their respective accounts, if this had not been done already. 
Some embodiments unreserve prior to auction close and other embodiments unreserve after the 
auction closes, 

15 In another embodiment of the Progressive Auction format, the successful bidders for a 

quantity of an item pay the lowest successful bid price in their group, where the group consists 
of the successful bidders who bid for that quantity of items those successful bidders who bid 
for less than that quantity of items. To use the same twenty item example above, three bidders 
are successful for four items each, and four bidders are successful for two items each. The 

20 three bidders who each won four items successfully bid $50, $55, and $58, The four bidders 
who each won two items successfully bid $40, $42, $45, and $48. The lowest bid price among 
the successful bidders who each won four items or less is $40. Thus, each of the successful 
three bidders who won four items each need to pay only $40 each because this is the lowest 
successful bid price among those who bid for four items or less. The four bidders who each 

25 won two items also pay $40 each. This embodiment provides an incentive for volume bidding 
since the successful bidders at the higher item quantity pay at the lowest bid price among those 
successful bidders who bid at that higher item quantity or less. 

In this embodiment, the grouping would be different for the purposes of determining a 
bid price. So, although one bidder who bid for 9 items may reference the bid price of a bidder 
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who bid for 5 items, the latter bidder cannot reference the bid price of the former bidder. 
Thus, with respect to FIG* 8, K is not a single fixed number; rather it is a variable number that 
is the bidder's quantity or less, 

6.4 BUY-OR-BID AUCTION 
5 Another format is Buv-or-Bid Auction format. This format is a variation of the 

Standard Auction format and was briefly discussed above. Here, the Yahoo! Auction System 
awards the merchandise to bidders who place bids at or above a posted selling price. This 
format guarantees the item to the bidder who bids at this posted selling price provided the 
inventory can support his requested quantity. Those bids that are not at or above the posted 

10 selling price are stored in reserve. If a predetermined sales volume has not been achieved after 
a specified time period, the posted selling price is lowered by some predetermined decrement. 
Those bids in reserve that are at or above this new posted selling price are deemed successful 
and the requested merchandise is awarded to these bidders. Those bids that are still below this 
new posted selling price are kept in reserve. This process continues until certain pre-auction 

15 termination conditions set by the seller have been reached. These conditions may include 

maximum number of selling price reductions, sales volume level, time period for auction, total 
items sold, or any combination of these conditions. 

Conversely, if the sales volume has been achieved within the specified time period for 
the auction, the Yahoo! Auction System will increase the posted selling price by a 

20 predetermined increment in accordance with pre-auction instructions from the seller. This 

feature allows the Yahoo! Auction System to adjust prices in response to market fluctuations so 
that the seller can sell the given items at the highest possible price that the market can support. 

One embodiment of the Buy-or-Bid Auction format in the Yahoo! Auction System and 
25 how it implicates the users* respective accounts will now be described with respect to FIG. 9. 
The auction begins at step 260. 

At step 261, the Yahoo! Auction System offers N items at starting bid price P each with 
a minimum increment dP and an initial sell-off price Psell- The seller has also specified to the 
Yahoo! Auction System that the sell-off price decrement is Pdecr the event that the N items 
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do not sell at the initial sell-off price Psell- For the auction of multiple items, these N items 
will be awarded to the bidders who bid at or above the sell-off price Psell- 

At step 262, the Yahoo! Auction System waits for or inquires about any new bid(s). If 
no new bid is forthcoming, the Yahoo! Auction System proceeds to step 273, which checks for 
5 any auction termination condition (as discussed above). If any auction termination condition is 
present, the auction terminates at step 275; otherwise, the Yahoo! Auction System proceeds to 
step 270 to check for the presence of any sell-off price adjustment condition. An example of a 
sell-off price adjustment condition is the failure to reach a particular sales volume within a 
predetermined time period. When this condition is satisfied, the sell-off price is adjusted (i.e., 

10 lowered) to entice bidders to bid on the items at step 271. 

If a new bid is received, such as BIDj^ew by a new bidder (whoever this may be) at step 
263, the Yahoo! Auction System checks for the validity of BID^ew step 264. If this is the 
very first bid, checking validity means that BIDjs^e^ "i^st be at least the starting bid price P. If 
this bid is an attempt to outbid an already existing high bid, the new bid BID,^£v/ ^^^st be at 

15 least the sum of the current high bid and the minimum bid increment dP. Other validity checks 
are described elsewhere in this patent specification. If BID^ew is not valid, the Yahoo! Auction 
System returns to step 262 where it checks for other new bids. 

If BIDnew is valid, the Yahoo! Auction System proceeds to step 265 where the system 
checks the new bidder's account to determine if BID^ew points are available. This ensures that 

20 the new bidder has enough points in his account so that if he is ultimately a winner for this 
auction, the seller of the N items can be paid at BIDj^ew points per item. If BIDj^gw is not 
available in the new bidder's account at step 265, the Yahoo! Auction System proceeds to step 
262 where the system checks for new bids. 

If BIDnew is available in the new bidder's account at step 265, the Yahoo! Auction 

25 System proceeds to step 266. Here, the system checks if BID^ew is greater than or equal to the 
sell-off price PgELL- ^II^NEw is l^ss than the sell-off price Psell? then the system proceeds to 
step 267 where this valid bid BID^gw is saved for future reference. After all, the sell-off price 
PjELL be decreased later and this bid BIDj^iew then be greater than or equal to the 
adjusted Psell l^vel. The system then returns to step 262 where it checks for new bids. 
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If BIDnew is greater than or equal to the sell-off price Pjell step 266, the system 
proceeds to step 268 where it sells the item at the bid price BID^ew to the new bidder. At step 
269, the system decrements the quantity of items available since this new bidder has been 
awarded one of the items. 
5 At step 270, the system checks check for the presence of any sell-off price adjustment 

condition (e.g., failure to reach a particular sales volume within a predetermined time period). 
If this condition is not satisfied, then the system returns to step 262 where it checks for any 
new bids. If this sell-off adjustment condition is satisfied at step 270, the sell-off price is 
adjusted (i.e., lowered) to entice bidders to bid on the items at step 27 L The new adjusted 
10 sell-off price is Psell~Psell"-Pdecr' that is, the initial sell-off price Psell t^kes on a new value 
which is Psell-Pdecr- 

At step 272, the system checks those saved bids that are now greater than or equal to 
the newly adjusted sell-off price Psell- If ^^ist, the corresponduig bidders are awarded the 
items at the bidders' respective bid prices. If the number of saved bidders who satisfy the 
15 adjusted sell-off price exceeds the inventory, then the system applies the first-in-time rule 
(based on bid reception date) to resolve conflicts. Also, the item quantity now available to 
bidders is also adjusted at step 272 to reflect the inventory. 

At step 274, the system then checks for any auction termination condition (as discussed 
above). If any auction termination condition is present, the auction terminates at step 275; 
20 otherwise, the Yahoo! Auction System returns to step 262 to check for any new bids. 

6.5 DECLINING BID AUCTION 

Another auction format is the Declining Bid Auction . In this format, the auction sells 
multiple items beginning at a starting maximum price of P points. Periodically, the auction 
system decrements the price P by some predetermined decrement dP, so that a future price 
25 would be P=P-dP; that is, the old P value would be replaced by the new P value which is the 
decremented value from the old P value. The auction has a relatively short duration, but as 
time passes by, the price P would slowly be lowered. Whenever any bidder wants one of the 
auctioned items, he would submit a bid. However, the bid amount is based on the particular 
price P at the time of the bid. 
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In one embodiment, the actual price that the winning bidders pays for each item is 
based on the lowest successful bid price. Thus, if the top five bidders for five computer 
monitors bid 50 points, 40 points, 35 points, 32 points, and 30 points, each of the five bidders 
would pay only 30 points, because this the lowest successful bid. In this format, the bidder 
5 must not bid too soon or else he may unwittingly force the other bidders to also bid soon, 
which may ultimately lead to higher prices. On the other hand, if a bidder waits too long to 
bid, he may not win the items. Of course, the bidder should submit a bid at a high enough bid 
price to secure the item because he knows that he will not have to actually pay at this bid price 
but rather the bid price of the lowest successful bid. 

10 One particular embodiment of the Declining Bid Auction format in the Yahoo! Auction 

System and how it implicates the users' respective accounts will now be described with respect 
to FIG. 11. The auction begins at step 280. 

At step 281, the Yahoo! Auction System offers N items at starting bid price P each with 
a minimum decrement dP for a time period T in accordance with the seller's pre-auction 

15 instructions. For the auction of multiple items, these N items will be awarded to the top N 
bids (however they are distributed among the bidders) at the bid price of the lowest successful 
bid. At step 282, the Yahoo! Auction System waits for or inquires about any new bid(s). If no 
new bid is forthcoming, the Yahoo! Auction System proceeds to step 289, which checks for 
any auction termination condition (as discussed above). If any auction termination condition is 

20 present, the auction terminates at step 293; otherwise, the Yahoo! Auction System proceeds to 
step 291 to determine whether the auction system should decrement the bid price P. 

If, at step 291, the system determines that it is now time to decrement the bid price P 
further, the system proceeds to step 292 where it decrements the bid price P from the old P to 
the new P (P-dP). Thereafter, the system proceeds to step 282 where it checks for any new 

25 bids. 

If a new bid is received at step 282, such as BIDi^fEw by a new bidder at step 283, the 
Yahoo! Auction System checks for the validity of BID^sjew step 284. For this Declining Bid 
format, BID^ew is the same as the current bid price P. Also, bid validity may be determined 
by merely checking whether the bidder is properly registered and whether the manner in which 
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the bid was submitted complies with the Yahoo! Auction System's rules. If BID^ew is not 
valid, the Yahoo! Auction System returns to step 291 where it checks for whether the system 
should decrement the bid price P further. 

If BIDnew is valid, the Yahoo! Auction System proceeds to step 285 where it 
5 determines BID^in, which is the lowest bid among the top N bids. At step 286, the system 
checks the new bidder's account to determine if BIDj^j^ points are available. This ensures that 
the new bidder has enough points in his account so that if he is ultimately named as one of the 
top successful bidders for this auction, the seller of the N items can be paid at BID^ji^ points 
per item. If BID^in is not available in the new bidder's account at step 216, the Yahoo! 
10 Auction System proceeds to step 290 so that BID^^j^ reverts back to the previous value since 
the new bid will not be among the top N bids. The system then returns to step 291 where it 
checks for whether the system should decrement the bid price P further. 

If BID^iN is available in the new bidder's account at step 286, the Yahoo! Auction 
System proceeds to step 287. Here, the system reserves BID^in in the new bidder's account so 
15 that this reserved amount of points cannot be used for other transactions. If the auction were to 
end now, all of the top bidders pays the same bid price BID^i^. 

At step 288, the system adjusts the other bidders' respective accounts so that BIDj^un is 
reserved, which may involve calculating differentials. The system then proceeds to step 289, 
which checks for any auction termination condition. If any auction termination condition is 
20 present, the auction terminates at step 293; otherwise, the Yahoo! Auction System returns to 
step 291 to determine whether the auction system should decrement the bid price P. 

At the conclusion of the auction, the Yahoo! Auction System actually deducts the 
reserved amount (or the winning bid amount if the winning bid amount is different from the 
reserved amount) from each winner's account. Also, the other reserved amounts of non- 
25 winners (if any) are unreserved in their respective accounts, if this had not been done already. 
Some embodiments unreserve prior to auction close and other embodiments unreserve after the 
auction closes. 

In another embodiment, the system reserves BID^ew instead of BID^in if available in 
the bidder's account. Also, the accounts of the other top bidders need not be adjusted at the 
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time that BID^e^ is reserved in the new bidder's account. However, at the end of the auction, 
the system processes the accounts of all the successful bidders and make adjustments as 
necessary so that the successful bidders pay at the lowest successful bid price BIDj^j^. Note 
that one of the BID^ew bids will be the lowest successful bid price. This reduces the amount of 
5 traffic and computing that are necessary to perform the accounting task for all the top bidders 
since this adjustment is done only once at the end of the auction. 

In a further embodiment of the Declining Bid format, the winning bidders do not pay at 
the bid price of the lowest successful bid. Instead, the winning bidders pay at their respective 
bids as the bid price is slowly decreased during the time period of the auction. In this 

10 embodiment, the flowchart of FIG. 11 is applicable except for the bid amount reserved. 

Instead of BIDj^i^* the system reserves BID^g^ if available in the bidder's account. Also, the 
accounts of the other top bidders need not be adjusted since the top bidders pay for the items at 
their respective bid prices. 
7.0 AUTOMATED CLOSING 

15 In one embodiment of the present invention, the auction closes automatically after the 

expiration of a specified time period (e.g., 48 hours). The range of time periods that are 
available is anywhere from 2-14 days. This ensures that the auction is not open indefinitely. 
This time period is specified by the seller in the form of pre-auction instructions to the Yahoo! 
Auction System. In other cases, the auction seller may have a default setting of 72 hours - a 

20 time period which is not too and not too short. 

Normally, the time period should be selected such that it is long enough to optimize its 
exposure to potential bidders so that they may participate in the auction and short enough to 
maintain the high interest level of the average bidder, encourage the high energy frenzy of 
bidding activity which usually results in a higher winning bid, and promote the timely 

25 finalization of the sales transaction so that bidders and sellers may participate in other auctions 
(if they are not doing so already). This is important because even though bidders can 
participate in multiple auctions simultaneously, they may be hesitant to do so for various 
reasons - limited account balance, loss of "control," and the lower psychological energy rush 
due to spreadmg around the bidder's focus, among others. Many human bidders are not adept 

59 

SV/103327.01 
08142000/13:06/18568.1 



at multitasking. By shortening the time period for the auctions, each auction will close faster 
which allows the bidder to participate in other auctions. 

In another embodmient of the present invention, the auction may close earlier than 
scheduled if no new bids are received within some predetermined period. For example, let's 
5 say a particular auction for item X is scheduled to last for five days from 8:00 AM Monday to 
8:00 AM Saturday, The seller has also instructed the Yahoo! Auction System that if no new 
bids are received within a 48-hour period at any time during the five days or a 12-hour period 
after Wednesday 8:00 AM, then the auction should close immediately. This closing condition 
is also posted to potential bidders so that they are aware of this potential for premature closing. 

10 So, assume that a bid has been received at 1 :20 PM on Tuesday. On Thursday at 1 :20 PM, 
no new bid has been received since that last bid on Tuesday at 1:20 PM. At this point, 48 
hours have elapsed and the Yahoo! Auction System closes immediately and awards the 
merchandise to the bidder who submitted the bid on Tuesday at 1:20 PM. To use another 
example, assume that a bid has been received on Friday at 7:25 AM. However, by 7:25 PM 

15 on Friday, no new bid has been received. Since 12 hours have elapsed and it is after 

Wednesday 8:00 AM, the auction closes immediately and the Yahoo! Auction System awards 
the merchandise to the bidder who bid on Friday at 7:25 AM, 

This feature of prematurely closing the auction when the bidding activity has died down 
may encourage bidding during a shorter time period because bidders are notified that the 

20 auction may close abruptly if bidding is inactive. Accordingly, bidders may be motivated to 
remain active in the bidding process to prevent the closure of the auction. If a certain bid has 
been the high bid for some time, another bidder will be motivated to outbid the current high 
bidder now or else the Yahoo! Auction System may prematurely close the auction for 
inactivity. Furfliermore, this feature may allow more merchandise to be auctioned off in a 

25 shorter period of tune since the auction automatically ceases when the bidding is inactive for 
some predetermined length of time. 
8.0 AUCTION ALERT 

In accordance with another embodiment of the present invention, once a bidder has 
participated in an auction (i.e., by submitting a bid), the Yahoo! Auction System will alert the 
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bidder of other auctions of identical or similar items that are either currently active or coming 
up in the near future. This feature is attractive to a participating seller because the Yahoo! 
Auction System advertises that seller's auctions to those bidders who may otherwise not be 
aware of such auctions. This ensures that the Yahoo! Auction System will attempt to deliver 
5 as large a pool of bidders as possible to that seller's auction. In effect, the Yahoo! Auction 
System advertises other related auctions to the potential bidders based on his bidding activity in 
an auction. 

For example, assume that four separate auctions are currently being held to auction off 
four similar 17-inch color monitors owned by four different sellers. Also, a similar monitor 

10 will be auctioned off beginning tomorrow in another separate auction. A typical customer who 
has already registered with the Yahoo! Auction System is interested in buying a 17-inch color 
monitor. He sees the notice of a currently active 17-inch color monitor auction on the Yahoo! 
Auction System's web site. He immediately accesses that auction and submits a bid. The 
Yahoo! Auction System receives his bid soon thereafter, checks for validity, and if it is valid, 

15 saves ±is bidder's name and bid in ±e appropriate databases as the current high bidder and 
current high bid. The Yahoo! Auction System also sends this bidder a notice via email or the 
web page that three other auctions are currently active for the item (i.e., 17-mch color 
monitor) he is pursuing. Also, the Yahoo! Auction System also notifies him that another 
auction for a similar 17-inch color monitor will commence tomorrow. At this point, this 

20 bidder is now notified of all other auctions that are either currently active or will commence in 
the near future for the very item he is interested in purchasing. He may then participate in 
these other auctions to maxunize his chances of winning, and if the Yahoo! Auction System 
permits, he may even cancel his currently submitted bid so that he can focus on another 
auction. 

25 In another embodiment of the present invention, the customer may want to be 

automatically notified if any of the following conditions are satisfied: (1) a selected seller is 
conducting another auction or has scheduled an auction in the near future, (2) a selected item 
or category of items is being auctioned, or (3) a selected bidder is participating in an auction. 
These features add to the attractiveness of participating in auctions so that the user is notified 
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of any auctions that he may potentially be interested in. Whether his interest is in a particular 
seller, item, or competing against a particular bidder, this feature allows the user to passively 
receive notifications so that he can decide if he v/ants to actively participate in them. 

The user may be interested in participating in all auctions where a particular seller is 
5 involved. The user's reasoning may be that the seller has high quality items or that this seller 
has a good reputation after a transaction has been consummated. Furthermore, this particular 
seller may be offering points that the buyer deems to be more valuable than those of other 
sellers. 

The user may also be interested in participating in all auctions where a particular item 

10 is being auctioned. Usually, this is not an entire category of merchandise, where the term 
"category" is used to describe those goods on the Yahoo! Auction System's homepage. 
Usually, if the user is interested in baseball cards, he may want some notification of all 
baseball card auctions so that he may participate in them. The user may also be interested in 
17-inch computer monitors of a certain brand. 

15 Furthermore, the user may be interested in participating in those auctions where a 

particular bidder is a participant, regardless of seller or merchandise. Here, the user may be 
motivated by pure competitive fire. On the other hand, the user may have determined that this 
particular bidder has sunilar interests and to the extent that this bidder has some insights on 
some bargains, the user would like to be notified. 

20 In another embodiment, an auto-refresh feature is implemented. So, if no winning 

bidder has been determined during tfie course of the auction, the Yahoo! Auction System 
automatically resubmits the auction to allow users to participate. For those users who had 
previously participated but were not declared the winner, this refresh feature allows them to 
participate again. For those users who did not participate in this auction before, this refresh 

25 feature allows them to participate for the first time. 

Another feature is an auto-extension of auctions. During the course of the auction, if 
bids are submitted in the last X minutes (e.g., last 5 minutes until closing), the Yahoo! Auction 
System will extend the auction for another Y minutes. This feature prevents those users who 
attempt to strategically "swoop in" in the last few minutes or seconds to win the auction. In 
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one embodiment, the X minutes can range anywhere from the 5-30 minutes and Y minutes can 
range anywhere from 15-120 minutes. 
9.0 AUTOMATED BIDDER 

Another embodiment of the present invention provides for the automated bidder or 
5 some aspect of bidding by proxy. An advantage of conducting a sales transaction online 

through an electronic Yahoo! Auction System is the ability to automate almost every aspect of 
the transaction. The online and electronic nature allows the bidder to participate in auctions 
without physically being present at the auction floor. Indeed, in the auctions held by the 
Yahoo! Auction System of the present invention, the traditionally known auction floor does not 

10 exist since all transactions occur electronically. Bids can be submitted from almost any place 
on earth (or outside earth) so long as the electronic communication medium (e.g., telephone 
lines, free space with appropriate radio transmitters/receivers or optical transmitters/receivers) 
is available and connected to the remote Yahoo! Auction System. Also, the electronic nature 
of the Yahoo! Auction System of the present invention allows bidders to participate in multiple 

15 auctions simultaneously, which was physically impossible in the traditional auction houses. 
Furthermore, the electronic nature of the Yahoo! Auction System allows the human bidder to 
automate his actions so that he does not have to be physically present at this computer to locate 
an auction, submit a bid, or finalize a sale. 

In accordance with one embodiment of the present invention, the Yahoo! Auction 

20 System allows any registered bidder to automate particular bidder-side aspects of the bidding 
process so that he does not have to manually participate in the auction. The automation 
involves an agent application process at the client computer. In another embodiment, the agent 
application resides in the server of the remote Yahoo! Auction System but associated with the 
user. The automation involves the configuration of certain settings of the agent process by the 

25 user. Some configurable settings include maximum bid amount, out-bid increment, start bid 
enable, and item quantity. For these settings to function properly, the user must select a 
particular auction or auctions. These settings can be set at the time of the auction or in 
advance of the start of the auction. 
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The maximum bid amount places a ceiling on the amount that the bidder is willing to 
bid on an item. For example, assume that the current high bid for an item is $490. The 
required increment is $10 for this auction. The user has set his maximum bid amount of $500 
and an out-bid increment of DEFAULT, which informs the Yahoo! Auction System that the 
5 required increment will be observed. The client computer process at the bidder's side submits 
a bid of $500 to the Yahoo! Auction System. If no other higher bid has been received by the 
Yahoo! Auction System and it receives the user's bid of $500, the user's bid will now be the 
current high bid. If another bidder out-bids this current high bid to $510, the user's agent 
process will not submit another bid because the minimum valid bid is $520 (current high bid 

10 $510 + default increment of $10) which is greater than the maximum bid amount specified by 
the user in the agent process settings. With this setting, the user can control how much 
payment units (in the form of cash or points) he is willing to use up to obtain this particular 
item through this Yahoo! Auction System. Of course, if the user intervenes during the auction 
process, he may manually override this maximum bid amount setting quickly and easily. 

15 The maximum bid amount is applied with some checks. If the user's account does not 

have enough payment units to cover the maximum bid amount specified for the agent process, 
the Yahoo! Auction System will either disallow the participation of the user in that auction, 
suggest a lower maximum bid amount that can be covered by the user's account balance, or 
allow the user to participate provided that the credit line in the user's account is not exceeded. 

20 Normally, the Yahoo! Auction System will prompt the user with the first two options - 

disallow participation and suggest a lower maximum bid amount. The third option is available 
provided that the Yahoo! Auction System has enabled the credit feature of the user's account. 
Not every account has a credit line and credit balance because of the inherent risks of offering 
credit to those users who are not credit worthy. Also, the user's account is periodically 

25 checked to ensure that sufficient payment units are available to cover any outstanding bids 
because even though the account may have had sufficient payment units yesterday, it may not 
have enough payment units today in light of other intervening transactions that may have 
occurred. 
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The out-bid increment can be set to either DEFAULT or some other value. If the 
setting is DEFAULT, the agent process uses the required bid increment for the particular 
auction selected by the user. Because each auction's bid increment may be different, the 
DEFAULT setting allows the user to comply with the minimum required bid increment for 
5 each auction. The user may also use some bid increment value that is not equivalent to the 
required bid increment for the auction. Normally, this bid increment value is some amount 
above the minimum required bid increment so that the user's bid is valid. If some absolute 
value regardless of the required bid increment is selected, the user runs the risk of having his 
bid rejected by the Yahoo! Auction System for being invalid (i.e., below the required 

10 minimum bid increment). The user may want to use this value instead of the DEFAULT value 
because of some perceived advantage that they will outbid other bidders. Some of these users 
assume, rightly or wrongly, that most bidders will only submit a bid that satisfies the absolute 
minimum increment (i.e., current high bid + required minimum bid increment). Thus, by 
submitting a bid that is above the required bid increment, these users believe that they will 

15 have a better chance of outbidding competitors. 

Like the maximum bid amount setting, the out-bid increment is also applied with some 
checks. First, when the agent process applies the out-bid increment to the current high bid, it 
also checks the maximum bid amount to ensure that the user*s new bid does not exceed the 
specified maximum bid amount. If the new bid does exceed the maximum bid amount, the 

20 agent process does not submit the new bid to the Yahoo! Auction System. Also, the new bid 
amount is compared to the user's account balance to ensure that the user has sufficient payment 
units to cover the new bid amount since the agent process does not know in advance whether 
the new bid will be successful or not. If the account is associated with credit, the new bid 
amount is compared to the authorized credit line to ensure that the new bid amount does not 

25 exceed the credit line. 

The start bid enable setting allows the user start the bidding process for any specified 
auction, whether currently active or scheduled to commence sometime in the near future, by 
submitting a bid. With this feature, the bidder need not manually be present at his computer 
station to submit the starting bid. The bidder specifies two starting bid prices - one for those 
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auctions where the starting bid price is not specified and the other for those auctions where the 
starting bid price is specified. For those auctions where the starting bid price is not specified, 
the user sets some bid value, which is usually very low. For those auctions where the starting 
bid price is specified, the user may either set a default value or some other specific value. The 
5 default value is the starting bid price specified by the seller (via the Yahoo! Auction System). 
A non-default specific value can be provided as well and normally, this value is some amount 
above the starting bid price. If this value is set without any context of the required starting bid 
price, the user runs the risk that his starting bid price is below the required starting bid price 
and hence, invalid, 

10 Of course, regardless of whether the default value or some other specific value is set 

for the start bid enable setting, the agent process compares the starting bid price to the 
maximum bid amount to ensure that the starting bid price does not exceed the maximum bid 
amount. If the starting bid price does exceed the maximum bid amount, the agent process does 
not submit this bid and in effect, it does not participate in this auction. 

15 Another setting is the item quantity. Here, the user specifies the maximum and 

minimum item quantity. This setting is effective only for those auctions where multiple items 
are being auctioned off and bidders are allowed to bid for more than one item. The agent 
process initially selects the maximum quantity and submits a bid in accordance with the other 
settings described above (i.e., start bid enable, maximum bid amount, bid increment). 

20 Typically, the Yahoo! Auction System will accept this bid. Many times, however, the Yahoo! 
Auction System may reject this bid because the specified item quantity cannot be supported by 
the inventory. (Other reasons for bid rejection have been discussed above including someone 
else outbidding you or the auction has closed). If so, the agent process receives this 
notification from the Yahoo! Auction System and the agent promptly reduces the item quantity 

25 by one unit (so long as this reduction does not reduce the item quantity below the minimum 
item quantity specified by the user). The agent process then submits the bid again with this 
new quantity. This back-and-forth interchange between the Yahoo! Auction System and the 
agent process may continue indefinitely until the auction closes, the Yahoo! Auction System 
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can support the requested item quantity, or the agent process cannot lower the item quantity 
any further. 

Like the other settings, the agent process performs checks on the item quantity. This 
time, the agent must determine the total price (by multiplying the item quantity by the price per 

5 unit) and compare this total price to the user's maximum bid amount. If the maximum bid 
amount is not violated, the agent compares the total price to the user's account balance to 
ensure that sufficient payment units are available to cover the cost of purchasing these items if 
the user wins the auction. If the credit feature is associated with the user's account, the agent 
checks the user's credit line and credit balance to ensure that the user's credit is still usable. 

10 With this automated bidder feature, the human bidder can specify various parameters to 

the agent process which then acts on behalf of the user to compete (and win) the auction. 
Sufficient checks are provided so that the agent process does not deplete the user's resources. 
Even if the user wanted to deplete his resources, other checks are implemented so that the 
Yahoo! Auction System prevents the user from abusing his account (and credit). 

15 A particular implementation of the automated bidder feature in the Yahoo! Auction 

System and how it implicates the users' respective accounts will now be described with respect 
to FIG. 10. The auction begins at step 190. 

At step 191, the Yahoo! Auction System offers item X at starting bid price P with a 
minimum increment dP in accordance with the seller's pre-auction instructions. At step 192, 

20 the Yahoo! Auction System waits for or inquires about any new bid(s). If no new bid is 

forthcoming, the Yahoo! Auction System proceeds to step 198, which checks for any auction 
termination condition (discussed elsewhere). If any auction termination condition is present, 
the auction terminates at step 200; otherwise, the Yahoo! Auction System returns to step 192 to 
check for any new bids. 

25 At step 193, a new bid BIDnew by a new bidder (whoever this may be) is received by 

the Yahoo! Auction System. In this automated bidder feature, the new bidder has automated his 
bidding so that he can bid on item X even though he is not present at his computer station. He 
has specified a maximum bid of BID^ax and an increment of BIDj^cr, which is greater than or 
equal to the minimum bid increment dP. 
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At step 194, the system checks for the validity of BID^ew If this is the very first bid, 
checking validity means that BID^ew inust be at least the starting bid price P. If this bid is an 
attempt to outbid an already existing high bid, the new bid BID^ew i^^st be at least the sum of 
the current high bid and the minimum bid increment dP, Other validity checks are described 

5 elsewhere in this patent specification. If BIDnew is not valid, the Yahoo! Auction System 
returns to step 192 where it checks for other new bids. 

If BIDnew is valid, the Yahoo! Auction System proceeds to step 195 where it checks the 
new bidder's account to determine if BID^ew points are available. This ensures that the new 
bidder is bidding with points that he has so that if he ultimately wins the auction, the seller of 

10 item X can be paid. If BID^ew is not available in the new bidder's account at step 195, the 
Yahoo! Auction System returns to step 192 where it checks for new bids. 

If BIDnew is available in the new bidder's account at step 195, the Yahoo! Auction 
System proceeds to step 197. Here, the system reserves BID^ew *e new bidder's account 
so that this reserved amount of points can not be used for other transactions. If BID^^ew was 

15 submitted to outbid an already existing high bid, then the previously reserved high bid amount 
is unreserved in the previous high bidder's account. At this point, the new bidder is the 
current high bidder with the current high bid at BID^ew The system then proceeds to step 198 
to check for the presence of any auction termination condition. 

In other embodiments, step 197 does not unreserve any bids until after the auction 

20 closes. This is done as a precaution in case a wmning bidder backs out. Because other bids 
continue to be reserved, the bidder(s) associated with these bids may be the ultimate winner(s) 
in those infrequent occasions when a winning bidder changes his mind. In another 
embodiment, the Yahoo! Auction System prevents bidders from backing out since Yahoo! has 
control of his account. 

25 In an alternative embodiment, the Yahoo! Auction System proceeds from step 194 to 

step 196 while skipping step 195 altogether. At step 196, the system checks if BID^ax* which 
is the new bidder's maximum bid amount that he specified for his automated bidder setup, is 
available in the new bidder's account. This is done because, theoretically, the bidding process 
may escalate to this maximum amount and the new bidder may ultimately win the auction. At 
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step 199, the system reserves BIDi^^x the new bidder's account and unreserves any other 
previously reserved bid in the previous high bidder's account. Because the maximum bid 
BID^tAx is reserved, the system need not reserve the current high bid BID^ew (because BID^ax 
is greater than or equal to BID^ew)- Note that if the ultimate winner of the auction is the 

5 bidder who used the automated bidder feature, some additional accounting process is done at 
the conclusion of the auction. Remember that in this embodiment, the system reserved BID^ax 
from the new bidder's account. If the ultimate winning bid is BID^ew. where BIDj^ew is less 
than BIDmax' the difference must be put back into the winning bidder's account since all of 
BIDmax will not be needed to purchase item X. 

10 At step 198, the system checks for the presence of any auction termination condition. 

If no auction termination condition is present, the system returns to step 192 where it checks 
for new bids. If new bids are received, the system proceeds down the flowchart as described 
above. If any auction termination condition is present, the auction ends at step 200. 

At the conclusion of the auction, the Yahoo! Auction System actually deducts the 

15 reserved amount (or the winning bid amount if the winning bid amount is different from the 
reserved amount) from each winner's account. Also, the other reserved amounts of non- 
winners (if any) are unreserved in their respective accounts, if this had not been done already. 
Some embodiments unreserve prior to auction close and other embodiments unreserve after the 
auction closes. 

20 In another embodiment of the present invention, several bidders may automate the 

bidding process. Since these bidders have all specified a maximum bid amount, the Yahoo! 
Auction System need not check the bidders' respective accounts at each outbid increment since 
the outbidding will play itself out after time. 

For example, assume that bidder A has automated his bidding process with a maximum 

25 bid amount of 55 points with an outbid increment of 5 points. Bidder B also has automated his 
bidding process with a maximum bid amount of 65 points with an outbid increment of 7 points. 
Assume that bidder A has provided the starting bid at 30 points. Bidder B outbids bidder A 
with 37 points in accordance with the automated bidder instructions for bidder B. In this 
embodiment, the auction system does not check bidder B's account to check if 37 points is 
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available. Instead, bidder A now bids 42 points in accordance with his automated bidder 
instructions. Bidder B then bids 49 points. Bidder A then bids 54 points. Bidder B then bids 
61 points. At this point, bidder A cannot bid further because doing so would violate his 
automated bidding instructions which capped his bid amount at 55 points. The system then 

5 checks bidder B's account to make sure that 61 points are available. 

In another variation of the above theme, the amount reserved is the maximum bid 
amount at the time the bid is received by the auction system. To use the same example above, 
the auction system reserves 55 points in bidder A's account when bidder A's bid of 30 points is 
received. The auction system also reserves 65 points in bidder B's account when bidder B's 

10 bid of 37 points is received. At the conclusion of this auction, bidder B wins with 61 points. 
At this point, the auction system unreserves the 55 points in bidder A's account because bidder 
A lost. The auction system also unreserves 4 points (65-61 =4) in bidder B's account. 
10.0 AUTOMATED SELLER 

Another embodiment of the present invention provides for the automated seller or 

15 some aspect of selling by proxy. Most of the automated seller features have been discussed in 
this patent specification. Like the automated bidder, the Yahoo! Auction System sells the 
seller's merchandise based on instructions (i.e., settings) provided by the seller. In one 
embodiment, although an agent process at the client computer handles automated bidder tasks, 
the Yahoo! Auction System itself carries out the automated seller tasks, 

20 The seller normally provides time period-related settings to the Yahoo! Auction 

System. For all auctions, the seller can specify a specific time period including open and close 
dates/times for auctioning his merchandise. The open and close dates/times can be almost 
anything although the Yahoo! Auction System encourages the time period to be long enough to 
allow an optimal number of potential bidders to participate in the auction and short enough to 

25 keep bidders' interests and maxunize the number of auctions held every year. 

Alternatively, the seller can select a default setting. In one embodiment, the default 
setting is 72 hours and will open inraiediately. In another embodiment, the Yahoo! Auction 
System may suggest some dates/times based on the merchandise being auctioned off and times 
of peak auction activity. For example, assume that a seller has a bicycle that he wants to sell. 

70 

SV/103327.01 
08142000/13:06/18568,1 



The Yahoo! Auction System compares the time periods for auctions of bicycles and provides a 
report of the various time periods used by other sellers. The report also contains information 
on the average time period, ultimate selling price, and a histogram indicating the peak bidding 
activity. 

5 The seller may also want to close the auction prematurely, as described above in the 

automated closing feature section. The seller specifies a low bidding activity time period to the 
Yahoo! Auction System. Thus, if bidding activity is very low (or nonexistent) during this pre- 
specified low bidding activity time period, the auction closes abruptly and the merchandise is 
awarded to the current high bidder. For example, the seller can specify that if no bidding 

10 activity occurs during any 6-hour time period, the Yahoo! Auction System should close the 
auction immediately. The seller can specify numerous low bidding activity time periods for a 
single auction. For example, he may command the Yahoo! Auction System to close the 
auction whenever any of the following conditions is satisfied - no bidding activity within a 12- 
hour period, no bidding activity within a 2-hour period if only 24 hours remain until the 

15 scheduled close of auction, or no bidding activity within the first 48 hours of the opening of 
the auction. 

The seller can also specify the starting bid price. If the bidders do not bid the required 
starting bid price, the Yahoo! Auction System will reject the bid as being invalid. The seller 
can also specify the start-up time period, the number of start-up time periods, and the 

20 decrements for each start-up time period. The start-up time period is some specified time from 
the opening of the auction. If no bid has been received by the Yahoo! Auction System within 
the start-up time period, the seller can specify that the starting bid price be decremented by 
some amount to entice bidders to submit bids. The seller can set up a second start-up time 
period with an associated decrement if the revised starting bid price still does not entice 

25 potential bidders to submit bids. The seller can set up as many start-up time periods with their 
associated decrements. The Yahoo! Auction System also has default values for the start-up 
time period and the appropriate decrements and will suggest them to the seller to facilitate the 
sale of the seller's merchandise. 



71 



SV/103327.01 
08142000/13:06/18568 I 



As for the actual reception of bids, the seller can either specify some minimum 
increment value required for the bid to be valid or leave it in the default setting, in which case 
the Yahoo! Auction System decides for the seller. Typically, the default setting is 5 payment 
units. In another embodiment, the valid increment increases as the number of points associated 
5 with the current high bid increases. The table below shows one example of the varying valid 
bids: 



Current high bid 


Valid increment 


<100 


5 


101-500 


10 


501-1000 


20 


1001-1500 


25 


1501-2000 


30 



Like the floating closing feature which closes an auction prematurely if no bidding 
10 activity occurs within a specified time period, the Yahoo! Auction System provides a sell-off 
feature. The sell-off feature is normally associated with the Buy-or-Bid Auction format 
whereby the merchandise is immediately awarded to bidders who submit a bid that has a value 
that meets or exceeds some threshold sell-off value. Those bids that are less than the posted 
sell-off price are stored in reserve. This sell-off price is in effect for some specified time 
15 period which the seller sets. After this sell-off time period has expired and so long as 
inventory for the merchandise is available, the sell-off price can be lowered by some 
decrement. Those bids that are above this new (but lower) sell-off price win the merchandise 
and those bids that are below this sell-off price are kept in reserve. After some specified sell- 
off tune period, the Yahoo! Auction System lowers the sell-off price even further based on 
20 instructions from the seller (if the seller wants to decrement the sell-off price fiirther). 

The seller may also specify the names (i.e., YahooID) of those bidders that the seller 
prefers to block from bidding in certain or all auctions. For whatever reason, from bad prior 
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experience with a particular bidder or reported bad behaviors, the seller may block certain 
bidders from participating in some or all of a seller's auctions. 

In all of these cases, the Yahoo! Auction System actually conducts the sales process and 
transaction based on pre-auction instructions from the seller. In many cases, the seller may 

5 take the time to provide the specific settings to maximize his sales potential. In other cases, 
the seller may choose default values to quickly place his merchandise in play. Regardless, 
once the auction has opened, the Yahoo! Auction System is capable of conducting the auction 
and finalizing sales without any subsequent mtervention by the human seller. 
11.0 ACCOUNT CHECKS BEYOND THE INITIAL CHECK 

10 As mentioned in the various embodiments above, the Yahoo! Auction System checks 

the bidder's account at the time that a bidder makes a bid to determine if enough points exist in 
the account to afford the item(s) bid. In some cases, this involves comparing the actual 
nimiber of points bid (i.e., BIDnew) with the account balance and reserving these points if the 
account balance can support it. Some examples include the Standard Auction format, the 

15 second embodiment of the Dutch Auction format, and the Buy-or-Bid format. In other cases, 
the system compares some other number of points (i.e., BIDj^j^) that may not be the bidder's 
bid with the account balance and reserving these points if the account can support it. Some 
examples include the first embodiment of the Dutch Auction format and the Progressive 
Auction. In these instances, the auction system performs the account check at the tune the bid 

20 is received. 

In other embodiments, the Yahoo! Auction System does not perform the account check 
at the time of bid; rather, the system performs the account check for those bids received near 
the end of the auction. For many popular auctions, many bids are received during the course 
of the auction as one bidder tries to outbid another bidder. However, the ultimate winning bid 
25 will normally be one that was received near the end of the auction. 

By checking into the account database to verify that the requisite minimum balance 
exists and reserve the bid amount for every single valid bid, the Yahoo! Auction System 
generates a lot of network traffic and uses computing resources, especially if the account 
database is owned and operated by a third party. By limiting the inquiries and computations to 
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those bids that may ultimately be the winning bid (i.e., those bids that are received later in the 
auction rather than earlier), traffic can be minimized. This embodiment makes sense because, 
in many cases, a bidder is aware of his account balance and will refrain from engaging in any 
transaction that involves more points than he can afford. 

5 In some infrequent cases, however, a bidder may be unaware of his account balance 

altogether. Although the bidder's account could have satisfied a bid price yesterday, he may 
have conducted some other transactions today that depleted his account to such an extent that 
he no longer has the points to satisfy yesterday's bid today. In this case, another embodiment 
of the present invention includes some functionality in the Yahoo! Auction System that 

10 periodically checks each bidder's account status with respect to each auction for which he is a 
participant. This periodic check can be once a day, once every 12 hours, once every 6 hours, 
once every 3 hours, or some other frequency. Whether the check is for his actual bid (i.e., 
BIDnew) or some other bid value (i.e., BID^in) against his account, the Yahoo! Auction System 
performs the check based on the particular auction's rules and format. If a bidder's account 

15 ' status has changed such that he can no longer afford the requisite amount, the Yahoo! Auction 
System removes him from the top bidder list in his respective auction. In one embodiment, the 
reservation scheme is not implemented throughout the auction; instead, the system relies on 
periodic checks for the most part and reservations near the end of the auction. 

In another embodiment, the Yahoo! Auction System does not check the bidders' 

20 respective accounts periodically. Rather, the Yahoo! Auction System checks the bidders' 
respective accounts whenever the bidder conducts any transaction on the Yahoo! site. The 
transaction would be conducted using the user's YahooID, which would then flag the Yahoo! 
Auction System. The Yahoo! Auction System checks the YahooID from the flag with the 
bidder database. In most cases, the flag will identify a Yahoo! user who is probably not 

25 actively participating in any Yahoo! auction at the moment. If, however, the YahooID 
corresponds with a currently active bidder from the bidder database, the Yahoo! Auction 
System checks the bidder's account to determine if the bidder still has enough points to support 
the auction(s) he is currently participating in. If his account balance is too low, this bidder is 
removed from the relevant auction(s). The Yahoo! Auction System also notifies the user of his 
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removed status. If the user wants to participate further in the auction(s) from which he was 
removed, he would have to earn enough points to satisfy whatever thresholds have been set for 
the auction (e.g., highest bid for the Standard Auction, BID^in for the Dutch Auction, sell-off 
price for Buy-or-Bid Auction). 

5 A special case that occasionally occurs will now be discussed. What happens when 

some or all of the user's points are scheduled to expire prior to the official close of a particular 
auction? Of course, if the user is not a participant of that auction, no issue is raised. 

In accordance with one embodiment of the present invention, the Yahoo! Auction 
System will make a decision on whether to allow a user to bid based on some account checks. 

10 The Yahoo! Auction System first determines whether any points are scheduled to expire prior 
to the official close of the auction. If so, the Yahoo! Auction System performs a quick check 
of the user's account to determine the user's account balance after the expiration of the points. 
For those cases where the user is using the automated bidder feature, the Yahoo! Auction 
System compares the max bid amount with the post-expiration account balance. If the account 

15 balance can support the max bid amount, the Yahoo! Auction System will allow the user to 
participate in the auction and accept any valid bids by this user. If the account balance does 
not support the max bid amount, the Yahoo! Auction System will not allow the user to 
participate in the auction. 

In some cases, the user may not be using the automated bidder feature; that is, he is 

20 bidding manually. In these cases, the Yahoo! Auction System compares the current bid by the 
user to the post-expiration account balance. If the post-expu-ation account balance can support 
the user's current bid amount, the Yahoo! Auction System will allow the user to participate in 
the auction. If the post-expiration account balance does not support the user's current bid 
amount, the Yahoo! Auction System will not allow the user to participate in the auction. 

25 In another embodiment of the present invention, if any points are scheduled to expire 

prior to the official close of the auction, the Yahoo! Auction System makes a decision on 
whether to roll over the points into the next calendar quarter. This, in effect, rewards those 
users who submit a valid bid in an auction by extending the life of the points into the next 
calendar. In one embodiment, the Yahoo! Auction System furst determines whether any points 
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are scheduled to expire prior to the official close of the auction. If so, the Yahoo! Auction 
System performs a quick check of the user's account to determine the user's account balance 
after the expiration of the points. If the post-expiration account balance can support the current 
bid (for manual bidding) or the max bid (for automated bidding), no roll overs will be 
5 necessary and the user is allowed to participate. In another embodiment, the Yahoo! Auction 
System rewards the user anyway for participating and rolls over the points for expiration in the 
next calendar quarter. If the post-expiration account balance cannot support the current bid 
(for manual bidding) or the max bid (for automated bidding), the Yahoo! Auction System will 
roll over the points that are scheduled to expire in this calendar quarter into the next calendar 
10 quarter and allow the user to participate. 

In a furdier embodiment of the present invention, the Yahoo! Auction System will let 
users participate in auctions so long as the current bid (for manual bidding) or the max bid (for 
automated bidding) is reserved at the moment. Thus, any amount that is reserved will not 
necessarily expire at the time of the expiration date. So, the Yahoo! Auction System first 
15 determines whether any points are scheduled to expire prior to the official close of the auction. 
If so, the Yahoo! Auction System performs a quick check of the user's account to determine 
the user's account balance after the expiration of the points. If the post-expiration account 
balance can support the current bid (for manual bidding) or the max bid (for automated 
bidding), no fiirther action is necessary since the user can clearly participate. If the post- 
20 expiration account balance cannot support the current bid (for manual bidding) or the max bid 
(for automated bidding), and the pre-expiration account balance can support the bid, the 
Yahoo! Auction System will flag the points that are scheduled to expire. The Yahoo! Auction 
System allows the user to participate and will reserve the bid amount (which includes the 
flagged points). Once reserved, the expiration date will have no effect on these points because 
25 they are flagged. If the user ultimately wins the auction item, the points (flagged and 

otherwise) will be deducted from the user's account. If the user does not ultimately win the 
auction item, the Yahoo! Auction System removes the flags from the flagged points. 
Thereafter, these points will then expire. In another embodiment, these flagged points will not 
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necessarily expire if the user ultimately loses the auction; rather, the flagged points will expire 
at the end of the next calendar quarter. 

12.0 POINT CREDIT 

5 In accordance with one embodiment of the present invention, a user may participate in 

an auction even though he lacks the points in his account. Because some users are very active 
customers or are otherwise considered a low credit risk, the Yahoo! Auction System may 
provide a "CREDIT APPROVED," "CREDIT WORTHY," or "CREDIT ENABLED" 
marker in the user's account. This marker indicates that the user of this account can purchase 

10 items or participate in auctions on credit points. The Yahoo! Auction System may also specify 
the credit line as well as a credit balance. So long as the user remains credit worthy, the lack 
of points in his account should not be an obstacle to making purchasing decisions. Of course, 
in order for the user to remain credit worthy, he would have to pay back the borrowed points 
at some time in the near future. Thus, for all the different embodiments described in this 

15 patent specification where the Yahoo! Auction System checks the bidders' respective accounts 
to determine whether sufficient points are available to support the bid, the Yahoo! Auction 
System checks for the "CREDIT ENABLED" marker, and if it exists, reserves the requisite 
number of points from the user's credit line. 

In a preferred embodiment, the account that keeps track of credit line and credit balance 

20 is maintained in a separate third party server's database. In this embodiment, Yahoo! would 
prefer to not be involved in the day-to-day management of the users' accounts. Note also that 
the extension of credit can be provided by third-party credit companies (e.g.. Visa), as well as 
by Yahoo! itself. 

13.0 YAHOO!/MERCHANT RELATIONSHIP 

25 In accordance with one embodiment of the present invention, most of the sellers of 

merchandise in the Yahoo! Auction System will be corporate merchants as opposed to 
individuals. In order to participate, each merchant must pay a fixed percentage commission 
(e.g., 2% of revenue) for the ability to give away Yahoo! Points. However, Yahoo! will 
provide an incentive for these merchants to get back most, if not all, of the commission. When 
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these issued Yahoo! Points are returned (i.e., redeemed) to the merchant, the merchant should 
report the return information to Yahoo. When the return information is received by Yahoo, 
Yahoo! will then remove the points from the user's account. Yahoo! will then pay back the 
commission on a prorated basis; that is, if all of the issued points are returned and the 
5 merchant reports this information, Yahoo! will pay back 100% of the commission, but if only 
40% of the issued points are returned, Yahoo! will pay back only 40% of the commission. 
This buy /refund system enables merchants to buy points so that they can distribute them as 
they wish and still be refunded a portion or all of the cost to buy these points by reporting 
returns to Yahoo. 

10 Similarly, advertisers will also be able buy points from Yahoo! so that they can use 

them on banner ads or simply award them to selected consumers. When users click on an ad, 
the click is linked back to the ad server which keeps track of the various points from various 
campaigns, whether Yahoo-related or not. After all, the advertiser may advertise on sites 
other than Yahoo's website and distribute points to consumers from other point programs. The 

15 ad server will then be able to provide a report to the advertiser who can then report the returns 
to Yahoo! for the refund. One scenario that falls under this class is when merchants purchase 
points from Yahoo! and private label them. These points are then issued as the merchant's 
own points in their own points program but Yahoo! will be able to track them during 
redemption for refund purposes. 

20 In another embodiment, Yahoo! does not give the Merchants anything for the points. 

Thus, no Merchant account would be necessary. For the winning bidder, points used in the 
auction to win the merchandise are deleted from the user's account but these points are not 
necessarily transferred to the Merchant's account. These points are simply removed from 
circulation. 

25 In another embodiment of the present invention, merchants can buy points from Yahoo! 

for a fixed purchase price. They can then distribute these points to any consumer in any way it 
pleases. The merchants could pay for their points by giving Yahoo! cash, traffic, advertising 
dollars, or any other form of compensation. For example, a merchant could buy 1,000 points 
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and then inform the consumers that the first 100 users to visit the Yahoo! website will earn 10 
points each. 

In another embodiment, merchants can earn points by auctioning off their items through 
the Yahoo! Auction System, Then, these merchants can take the points that they earned from 
5 the sale of their auctioned item and use them in any manner they desire. For example, a 
merchant auctions off 100 pairs of jeans within the Yahoo! Auction System. Assume that the 
merchant gained 100,000 points from the auction (e.g., 100 winners at 1,000 points each). 
The merchant can then give away the 100,000 points in then: website through some sort of 
sweepstakes or click-through ads. 

10 In a further embodiment, Yahoo! may permit the creation of a secondary market for 

points. Thus, merchants can buy, sell, or trade points with each other. A merchant with a lot 
of points can sell them to another merchant for cash, who can then use these points for 
marketing purposes to attract traffic to their website. In addition to merchants, points can be 
traded, bought, and sold by individuals in various markets. Users could create "bots" that will 

15 buy, sell and trade points with each other or barter them for goods and services Users could 
also act in concert and create buying groups that would band together to use their points as a 
bloc. Financial markets in points, including puts, calls, and other option type transactions 
could occur, especially with points of varying life and collectibility. 

Yahoo! could create a directory of point awarding sites and locations. This could be 

20 sorted by size, or by relevance to each user who sees it. Yahoo! could sell slots on this 
directory to merchants who want to attract attention from users. This directory could be 
delivered by email, served on the web, or delivered offline in a variety of media. 

Clubs could form that automatically donate all their points to a common cause, thus 
creating a secondary beneficiary to all points activity. Affiliate programs could exist that 

25 would pay individuals a share of all the points awarded to a friend any time that individual 
refers a merchant to a friend. Alternatively, a user could receive a share of a referral's point 
total forever, not just from the first referral. 

Private label programs in which other points programs are monitored and run by 
Yahoo!. For example, Nordstrom's could pay Yahoo! so that they could have their own points, 
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controlled by them and run by Yahoo!. Exchange rate and arbitrage issues would naturally 
emerge. As Yahoo! runs different points programs, Yahoo! can serve as an intermediary, 
offering real time exchange between one program and another, based on supply and demand. 
Alternatively, Yahoo can enable any individual or organization to set up its own exchange 
5 system. 

14.0 INTEGRATED POINTS SYSTEM 

One embodunent of the present invention is an electronic points system that allows 
consumers to redeem online those points that were earned offline. The offline-online incentive 
points system (hereinafter "Integrated Points System") will now be described. To place it in 

10 context, the Integrated Points System will be described with respect to a particular soft drink 
bottle caps program. A soft drink company is sponsoring a promotions program where certain 
bottle caps are worth so many points, A consumer buys a soft drmk bottle at a local store. 
The lucky consumer discovers that he is the beneficiary of a winning botfle cap, and in 
particular, a bottle cap that is worth N points. Instead of redeeming this winning bottle cap in 

15 the traditional way, the consumer logs onto the soft drink company's website and registers his 
bottle cap with the points. Thereafter, after registration, the consumer can redeem these points 
for any merchandise that is available for purchase with these points at any participating 
company's online store. 

In one embodiment, all of the bottle caps are worth the same number of incentive 

20 points. In other embodiments, the bottle caps are worth different number of points; that is, 
some are worth 500 points while others are worth 1,000 points, 

14.1 NETWORK ARCHITECTURE 

The online aspect of the Integrated Points System will be described first. Generally, 
any consumer who obtains some incentive points offline can register and verify these points 
25 online so that he can redeem these points later for prizes. The system configuration of the 

server and the databases will be described first followed by a discussion of the operation of the 
system. 

In accordance with one embodiment of the present invention, the Integrated Points 
System is implemented in an online networked environment. As shown in FIG. 1, a typical 
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network environment includes some client computer stations 101, 102, and 103 that are usually 
operated by a human participant of the Integrated Points System, These client computer 
stations are connected to the wide area network (WAN) of the Internet 120 via Internet Service 
Providers, or ISPs (not shown in FIG. 1), Other client computer stations 104 and 105 are part 
5 of a local area network (LAN) 100. This network also contains a server computer station 106. 
Server computer stations 110, 111, and 112 provide various functionality over the web. Each 
server can be accessed by their identifying uniform resource locator (URL) address (i.e., 
"ht^://www.serveraddress.com"). The Integrated Points System is a computer program that 
resides in and is executed primarily in at least one of these server computer stations, such as 
10 server 112. 

In one embodiment, the various screens use HTML. Other embodiments use XML 
(i.e., static objects from which various HTML pages could be generated dynamically) or some 
other format. The functionality of server 112 will be discussed in greater detail below. 

Client computer stations 101-105 are usually operated out of private residences, small 

15 offices, or even large corporate offices. Representative client computer stations are personal 
computers with modems (or network connections, e.g., to a router and high-speed Internet 
connection), terminal stations, and network servers. The client computer station is complete 
with a computer, keyboard, mouse, monitor and appropriate modem/bus/network interface. 
As known to those ordinarily skilled in the art, a representative client computer station 

20 includes a CPU, a local bus, a host/PCI bridge, memory bus, main memory, and hard disk 

memory. Exemplary client computer stations include a Sun Microsystems SPARC or ULTRA- 
SPARC workstation, an Intel/Microsoft-based computing station (e.g.. Gateway, Dell, 
Micron), and the Apple Macintosh. These client computer stations are capable of supporting 
various operating systems, including Solaris, Windows 98, Windows NT, and the Apple OS, 

25 Applications that run on these client computer station include email (e.g. , Microsoft 

Outlook Express, CCMail), web browsers (e.g., Netscape Navigator, Microsoft Internet 
Explorer), web servers, and community-based online services (e.g., AOL, CompuServe, 
Prodigy). Access to the Integrated Points System is made possible through a web browser for 
viewing web content in the form of HTML files. Through the web browser, cookies may also 
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be used to store state information such as user name, ID, password, user preferences, settings, 
and the like, as known to those skilled in the art. 

The email system can also be used to access the Integrated Points System for such tasks 
as communicating with technical support or submitting bottle cap number for registration. 
5 Purchases with incentive points can also be made via email. 

The corporate network 100 is usually implemented as a local area network (LAN) for 
intra-building or intra-campus communication. Where the corporate network 100 extends to 
multiple buildings or multiple campuses in different geographic locations, the corporate 
network 100 can be implemented as a wide area network (WAN) for inter-building or inter- 

10 campus communication that extends the mdividual LANs via common telephone carrier lines. 
These WANs typically employ bridges or routers to enable the communication over the 
common carrier lines. 

In one embodiment, the server 106 in the LAN network 100 may perform the 
functionality described in this patent specification. Thus, a company operating this network 

15 100 can award points to its employees and allow them to participate in certain offline-online 
programs for various prizes. 

The Integrated Points System in accordance with one embodiment of the present 
invention will now be described. Referring to FIG. 12, web server 400 provides the user 
interface to the Integrated Points System. As discussed above, the consumer can access this 

20 web server by entering a URL that has been marketed to the public. Typically, if the offline 
product is the soft drink bottle cap, the bottle cap itself may indicate the URL. Also, the 
consumer can also access the home website of the manufacturer of the soft drink. The web 
server supporting the manufacturer's home website also includes functionality to allow 
consumers to register/ verify their respective points. 

25 The web server 400 includes the appropriate user interface screen and functionality to 

securely allow only registered users to enter the site, access their respective account 
information, register to set up an account if an account has not already been set up, and/or 
verify a particular bottle cap code so that his account is updated with the offline-earned points. 
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The web server 400 is coupled to a bottle cap code server /production database 401 and 
user database 402. The web server 400 contains the necessary functionality to allow any 
consumer to register, which involves setting up an account with an ID (user name) and 
password. Once the account is set up, it is placed in the user database 402, The security 
5 features (user ID and password) that allow only registered users to view account information 
are implemented in the web server 400. 

At some point after registration, the user may want to make sure that his account is 
updated with his recently earned bottle cap points. This is called verification. For example, if 
the bottle cap says that the lucky user just earned 100 points, these 100 points must make their 

10 way somehow into his online account. The bottle cap is associated with a particular 10-digit 
code. When verifying a particular bottle cap, the user enters this 10-digit code and the bottle 
cap code server 401 verifies the validity of this 10-digit code. If the 10-digit code is valid, the 
user's account is updated with the points associated with this 10-digit code. If the 10-digit 
code is not valid, the user is asked to reenter the number. For repeated failed attempts to enter 

15 the 10-digit code, the web server 400 generates some alarm indication to prevent this user from 
entering the 10-digit code again or otherwise making an attempt to access the account. 

From the website associated with the Integrated Points System web server 400, users 
can access any participating web store's website via the web store's web server 403. The web 
store 403 is associated with a store database 404 which includes coupons, hard goods (e.g., 

20 iron, toaster, computer, printer), soft goods (e.g., downloadable music, downloadable 

software), and other inventory. The store database may also include account information of 
individual users who may or may not have set up an account with the Integrated Points System 
web server 400 and user database 402. The store web server 403 is also coupled to the user 
database 402. In another embodiment, the store database 404 is coupled to the user database 

25 402 via line 407. 

Similarly, from the website associated with the Integrated Points System web server 
400, users can access any participating auction website via that auction's web server 405. The 
auction website 405 is associated with an auction database database 406 which includes 
bidders, sellers, auction items, and outstanding bids. The auction database may also include 
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account information of individual users who may or may not have set up an account with the 
Integrated Points System web server 400 and user database 402. The auction web server 405 is 
also coupled to the user database 402. In another embodiment, the auction database 404 is 
coupled to the user database 402 via line 408. 

5 In one embodiment, the store web server 403, the auction web server 405, and web 

server 400 are all located in different locations. However, the store database 404 is co-located 
with the store web server 403, the auction database 406 is co-located with the auction server 
405, and the user database 402 is co-located with the Integrated Points System web server 400. 
The bottle cap code server and production database 401 is co-located with the web server 400. 

10 In one embodunent, as mentioned above, the users can access the various participating 

web stores, such as via web store server 403, and participating auction sites, such as auction 
server 405, from the Integrated Points System web server 400. In addition, users can access 
the Integrated Points System web server 400 from the participating web stores and auction 
sites. 

15 In another embodiment, the various servers and databases are all co-located together as 

shown in FIG. 13. In this embodiment, the server 400 is associated with the Integrated Points 
System. At the core of the server 400 is a front end server 301 which mterfaces with a 
database server 303, a messaging server 302, an authentication server 304, a bottle cap code 
server 317, and the Internet 120. The front end server 301 is further coupled to 

20 communications lines 314 (e.g., via a modem or network router connected to server 400) and 
the Internet 120. 

In one embodiment, the front end server 301 performs many tasks related to the 
management of the accounts, merchandises, coupons, incentive points, and auction bids. From 
executing code for any number of different applications, managing resources, handling web 
25 requests, managing files and records, creating files and records, deletuig files and records, 
delegating tasks, and handling exceptions, the front end server 301 provides the main 
processing for the server 400. Of course, this functionality, in other embodiments, could be 
distributed across multiple hardware servers. 
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The front end server 301 also works with a messaging server 302 via line 315 (e.g., the 
system bus or a network connection to another hardware server) and a database server 303 via 
line 311. The messaging server 302 works with the front end server 301 via line 315 and is 
also connected to the Internet via communication lines 313. The messaging server 302 
5 provides various messaging functionality in various communications media such as telephone, 
email, instant messaging, active desktop application, and web browser notices. For example, 
email notices such as product news, discount updates, and customer service access are 
provided via communications line 313. News of upcoming sales offers that may interest the 
potential customer are delivered frequently. Also, any questions that a user may have may be 

10 directed to customer service through the messaging server 302, which will direct the email to 
the appropriate personnel within the customer service department. As noted above, various 
forms of instant messaging as are well known in the art could replace some or all of the 
functionality of messaging server 302. 

Note that communications lines 313 and 314 are standard interfaces to the Internet 

15 (e.g., an Ethernet or other network mterface to a router and CSU/DSU, modem, etc.) or 
across machines which are typically Ethernet-connected at the "back end" of the network. 

In another embodiment, the front end server 301 and messaging server 302 are 
integrated in an Internet server 300. The interface to the Internet 120 is provided by primary 
communications line 314 (line 313 is not implemented). Thus, all web traffic passes through 

20 this Internet server 300 via communications line 314. The messaging server 302 

communicates with the front end server 301 and the back end of the system (e.g., database 
server 303). 

The database server 303 performs many tasks related to the creation, deletion, and 
management of various files and records managed by the server 400. The database server 303 
25 supports the front end server 301 in accomplishing its tasks of running the redemption portion 
of the Integrated Points System. The database server 303 includes a management tools and 
web page information unit 319. The management tools and web page information unit 319 
provides exactly that - tools for die web page administrator to update, modify, and 
troubleshoot his web site. The web page information is also provided therein so that the front 
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end server 301 accesses the web page information from this unit 319, Thus, when a user logs 
into the web page associated with server 400, the look and feel of this web page is stored in the 
unit 319. However, the web server does not access the unit 319 for each access of this web 
page; rather, the front end server 301 accesses the web information in the unit 319 only 
5 periodically to update its contents. 

The bottle cap code server 317 is coupled to the front end server 301 via line 318. The 
bottle cap code server 317 verifies that a submitted bottle cap code by a registered user is 
valid. If a valid code is submitted, the bottle cap code server 317 returns an acknowledgment 
to the front end server 301. If an invalid bottle cap code is submitted, the bottle cap code 

10 server 317 returns an error to the front end server 301 . 

The database server 303 serves a database of content, functionality, and user accounts. 
For example, database server 303 can serve an incentive points database 305, a coupon 
database 306, a merchandise database 307, an auction database 316, and an account database 
308. These databases are coupled to a communications line 310 and to the database server 

15 303. 

These databases on communications line 310 comprise the "back end" of the system. 
Note that the common bus-like illustration of the communications line 310 is merely 
conceptual. The databases may not actually be on a conmion bus. These databases may be 
widely dispersed geographically or integrated into one database. Also, some of the databases 

20 may be on a common bus while others may be located remotely and accessed via the Internet. 
The incentive points database 305 contains various incentive points banner ads and 
programs. Additionally, the prerequisites for earning these incentive points are also stored 
therein. Similarly, the coupon database 306 contains various coupon information that is either 
dissemhiated via the messaging server 302 or awarded to certain users when certain 

25 requirements are satisfied. Also, the merchandise database 307 contains various merchandise 
information that can be purchased by users or awarded based on satisfying certain 
requirements. These databases 305-307 can also contain links to specific web pages associated 
with the incentive point, coupon, or merchandise so that the user can be properly redirected to 
that website. In another embodiment, these databases do not contain ads, programs, coupons 
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or information; rather, these databases contain only links where the user can be properly 
redirected for more detailed information. The website associated with the link has the 
programs and coupons that are awarded to users. If necessary, these websites communicate 
with the account database 308 to keep credits, debits, and points information, 
5 The account database 308 is analogous to the user database 402 in FIG. 12 and contains 

information about each user's account. Normally, only a user with an account (i.e., member) 
gets the benefit of this Integrated Points System with points, coupons, and merchandise. The 
account information mcludes account balance (points or otherwise), expiration date for each 
point or group of points, redemption information, credit card information, billing information, 

10 billing address, and whether the account is authorized for using points for credit. Although 
this embodiment illustrated in FIG. 12 shows the account database 308 integrated with the rest 
of the server 400, another embodiment may have the account database located m a third party's 
server and maintained by the thhd party. 

These databases contain appropriate Imking fields so that an entry in one database can 

15 be associated with a related entry in another database. For example, when a user earns 
incentive points from the incentive points database 305, that user's account in the account 
database 308 is appropriately updated. 

In another embodiment, the incentive points database 305, the coupon database 306, 
and the merchandise database 307 are integrated into one database. The auction database 316 

20 and the account database 308, however, are kept separate. In still another embodiment, these 
databases are distributed across one or more machines. These machines are coupled via 
communications line 310 to the database server 303. These databases comprise the "back end" 
of the system which the Internet server 300 access. 

The authentication server 304 provides security functionality so that only those users 

25 with a proper account can access the features provided by the server 400. Typically, a user ID 
and password would be needed to access the account or even submit a bottle cap code for 
verification. 

The memory 309 provides support for the database server 303 and the authentication 
server 304 so that these servers can serve all the user requests coming in. For example, 
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hundreds if not thousands of users may be accessing this server 400 to register, access 
accounts, verify points, redeem points, shop, and/or participate in ongoing auctions. These 
requests are temporarily stored in the memory 309 until they are served by the database server 
303, the authentication server 304, or both, 
5 14.2 NETWORK OPERATION 

14.2.1 SYSTEM OVERVIEW 

The operation of the Integrated Points System will now be discussed. Continuing with 
FIG. 12, users may access the Integrated Points System either directly or indirectly. Direct 
access involves the user entering the URL associated with web server 400 via his web browser. 

10 Indirect access involves the user navigating to some other site which provides a link to the 
web server 400. In the latter case, the user may initially access the web pages associated with 
a particular store's web server 403, a particular auction web page associated with auction web 
server 405, some some search engine or web portal. These web pages provide a link to the 
URL associated with web server 400 and the user clicks on it. 

15 The Integrated Points System web page may be provided by a web server that is 

independent of the soft drink company (e.g., XYZ Corporation). Alternatively, the Integrated 
Points System web page may be integrated with XYZ Corporation's website. Once the user has 
accessed the Integrated Points System web page, the user is asked to enter a user ID and 
password. Alternatively, cookies may be used to store these state information so that the user 

20 need not remember the ID and password. After successfiiUy entering the user ID and 
password, the user has several options as described below. 

Referring now to FIG. 14(A), the main web page of the XYZ Corporation's bottle cap 
points program is displayed. Because the user has already been successfully authenticated, he 
is free to shop, view his account, or enter the bottle cap code for verification. In this example, 

25 this web page provides him with links to odier web pages for shopping opportunities such as 
clothes, toys, movies, music, travel, and consumer electronics. Clicking on any of the 
shopping buttons such as clothes, for example, would lead to a web page of links to those 
participating companies that sell clothes on the web. In a second embodiment, clicking on 
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clothes, for example, would lead to a web page of various categories of clothes and links to 
participating web stores that sell clothes in each of those categories. 

A third embodiment will now be discussed. Assume that the user clicked on 
"ELECTRONICS" on the web page shown in FIG. 14(A). In one embodiment, the next web 
5 page that the user sees is shown in FIG. 14(D). Here, flie web page indicates how many points 
the user has in his account. Also, a collection of consumer electronics items (e.g., items 1-8) 
that the user is able to purchase with his accumulated points are displayed. Because the user 
has only 3,000 points, only eight items are availabe for purchase. These eight items may range 
from a low end DVD player to a number of DVD movies. The user can purchase any of these 

10 available items with all or any portion of his accumulated points by clicking on the their 
respective links. On the other hand, the user can enter another bottle cap code, view his 
accoxmt, or shop for other types of merchandise. 

A fourth embodiment will now be discussed. Instead of the shopping categories (e.g. , 
clothes, toys, music) shown in FIG. 14(A), the user sees the web page shown in FIG. 14(E). 

15 Here, the user sees a table of store goods (both hard and soft) and their corresponding purchase 
price (points), current auction high bid (if it is available as an auction item), and any available 
coupons. So, in this example, the user has 3,000 points in his account. The web page lists in 
tabular form those items that the user can afford to purchase (or bid). Item 1 is available for 
500 points. If the user clicks on the coupon, the user can get 50 points off the purchase price 

20 of this item. This item 1, however, is not available as an auction item. Item 3, however, is 
available as an auction item with the current high bid at 960 points. If the user decides the 
purchase item 3 instead, he needs 1,200 points. A 100-point coupon is availabe for this item 
3. Finally, item 4 is available for purchase for 2,800 points but it is not available as an auction 
item nor is a coupon available. Like the other web pages, the user can also view his account, 

25 enter a bottle cap code for verification, and shop (e.g., web page of FIG. 14(A)). 

Returning to FIG. 14(A), if the user clicked on "ENTER CODE," the user would see 
the web page illustrated on FIG. 14(B). Here, the user is asked to enter the 10-digit code that 
is provided on the bottle cap. If the user enters an incorrect bottle cap code number (either 
through fraud or mistake), he is notified of the error and asked to try again. This process 

89 

SV/103327.01 
08142000/13:06/18568.1 



continues until the correct code is entered or some specified threshold limit has been reached. 
If the user reaches this threshold limit, the user's account is locked indefinitely until security 
issues have been resolved. In one embodiment, the threshold limit is 10 invalid attempts 
within a 30-minute span. 
5 If the user enters a correct bottle cap code on the web page shown in FIG. 14(B), his 

account is credited with those number of points associated with this valid bottle cap code. So, 
if his particular bottle cap is worth 100 points and his account balance is 4,000 points, entering 
the bottle cap code associated with this bottle cap would result in his account balance being 
updated to 4,100 points. 

10 The next web page that the user sees is that shown in FIG. 14(C). Here, the web page 

indicates that the user has entered a valid bottle cap code. In addition, this web page allows 
the user to enter another bottle cap code, view his account, or shop for merchandise with 
points or credit card. If the user clicks on the "CLICK HERE TO ENTER ANOTHER 
BOTTLE CAP CODE," then the web page looks similar to that shown on FIG. 14(B). If the 

15 user cUcks on "CLICK HERE TO SHOP," then the web page looks similar to that shown on 
FIG. 14(A). 

Shopping can be finalized as follows for two cases - (1) central shopping site, and (2) 
web store specific shopping site. In both cases, items of interest are selected and placed in a 
virtual shopping cart. Thereafter, the procedure diverges. 

20 In the first case where the user shops for goods of multiple web stores at a central 

shopping site, the user selects goods and coupons. Any selected coupons are applied to the 
purchase price of the goods in the user's shoppmg cart. Once at the checkout line, the user 
provides delivery information. For soft goods and some coupons (if the coupon is to be 
delivered and earned after the current purchase, such as "EARN 50 POINTS ON YOUR 

25 NEXT DVD PURCHASE"), the user provides his email address. For hard goods, the user 
provides a physical shipping address (i.e., street, city, state). 

For soft goods, the user is provided a confirmation code or special code (e.g., 12-digit 
code) to securely access a file server so that he can download his purchased soft good. He is 
then directed to that file server. If he elects to download his soft good at a later tune, he can 

90 

SV/103327.01 
08142000/13:06/18568.1 



use the special code for accessing that file server. The server also sends him the special code 
via email as return confirmation and as backup in case the user loses the special code for some 
reason. For coupons, the value, limitations, and expiration date of that coupon is updated into 
the user's account. For hard goods, die purchased good along with the shipping address is 
5 provided to a shipping clearinghouse which is responsible for delivering the hard good to the 
user in a timely fashion. 

In the second case where the user purchased goods from a particular web store, rather 
than a central shopping store, email confirmation is also used. For soft goods, the server sends 
an email to the user that has the URL address to a file server or the website of a particular 

10 manufacturer of the purchased soft good. In addition, the email contains a special unique code 
(e.g., 12-digit code). After the user accesses that file server or website, the user is asked to 
enter the special unique code. If the code is valid, the user is now able to download the soft 
good that he purchased. Similarly, the user is given a special unique code that represents a 
coupon, which is usually associated with some expiration date. When the user later decides to 

15 redeem his coupon, he can access the web store's site, select an item for purchase, and enter 
the coupon code so fliat the shopping server can apply the coupon's value to the purchase price 
of the item(s) in his shoppmg cart. 

In both FIGS. 14(A) and 14(C), the user is given the option to view his account. In 
FIG. 14(A), the web page provides a "VIEW ACCOUNT" button, while in FIG. 14(C), the 

20 web page provides a "CLICK HERE TO VIEW YOUR ACCOUNT" button. By clicking on 
either button, the next web page shows details of the user's account. The account shows the 
user's name, number of incentive points earned, number of incentive points spent (if any) 
widiin any specified time period, the last N (e.g., N=5) transactions regardless of whether 
pomts or cash was used, the last N transactions where points were used, dates of the last N 

25 bottle caps submitted and verified, items purchased, delivery information, dates of purchase, 
and any outstanding coupons. 

Alternatively, if the user enters a valid bottle cap code in the web page of FIG. 14(B), 
the next web page may be that shown in FIG. 14(A) with some additional indication that the 
user had entered a valid bottle cap code. At this point, the user can shop by clicking on any of 
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the shopping-related buttons, view his account, or enter another bottle cap code (if any). 
Regardless of how the web page looks, the basic functional design of any web page within the 
Integrated Points System is such that the user is able to shop, view his account, or enter a 
bottle cap code whenever he wants to with the click of a button, 
5 14.2.2 ENCRYPTION 

The encryption process involves the generation of billions and billions of unique codes, 
where a single code will be printed on the bottle caps and later verified online through the 
Integrated Points System. In addition, encryption is involved so that the creation of these 
codes will not necessarily result in the need for a lot of disk space. 

10 In one embodiment, approximately 2 billion codes will be selected such that the chance 

of guessing the codes is very very low. The alphabet for the codes includes thirty-six 
alphanumeric letters -A to Z and 0 to 9. To eliminate those letters that may look ambiguous 
(e.g., 5 and S; O and 0), the number of letters in the alphabet can be reduced. Based on the 
number of letters in the alphabet, a special fixed-length code that will be printed on the bottle 

15 caps can be generated. The following table shows the number of possible combinations for a 
given number of letters (L) in the alphabet and the number of letters (C) in the special code 
string: 



L 


C 




Odds: L^/2 billion 


36 


10 


3,656 trillion 


1 in 1,828,079 


35 


10 


2,758 trillion 


1 in 1,379,273 


34 


10 


2,064 trillion 


1 in 1,032,188 


33 


10 


1,531 trillion 


1 in 765,789 


32 


10 


1,125 trillion 


1 in 562,949 


31 


10 


819 trillion 


1 in 409,814 


30 


10 


590 trillion 


1 in 295,245 


29 


10 


420 trillion 


1 in 210,353 


28 


10 


296 trillion 


1 in 148,098 


27 


10 


205 trillion 


1 in 102,945 
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L 


C 




Odds: bUIion 


36 


9 


101 trillion 


1 in 50,779 


35 


9 


78 trillion 


1 in 39,407 


34 


9 


60 trillion 


1 in 30,358 


33 


9 


46 trillion 


1 in 23,205 


32 


9 


35 trillion 


1 in 17.592 


31 


9 


26 trillion 


1 in 13,219 


30 


9 


19 trillion 


1 in 9,841 


29 


9 


14 trillion 


1 in 7,253 


28 


9 


10 trillion 


1 in 5,289 


27 


9 


7 trillion 


1 in 3,812 



As explained above, "L" represents the number of letters in the alphabet. In this table, 
a 27-36 letter alphabet is shown. "C" represents the number of letters in the special code that 
will be printed on the bottle caps. In this table, the code can be either a 10- or 9-digit code. 
5 "L^" represents the number of possible combinations for a given letter (L) and code length (C) 
combination. 

billion" represents the odds of a user guessing a code at random and having it 
match one of the 2 billion legitimate codes. "L^/V" represents the general case where V is the 
desired number of valid legithnate codes. Thus, out of the 420 trillion possible combinations 
10 for a 10-digit code from a 29-letter alphabet, the distance between codes is roughly 210,353 
codes. 

In one embodiment, the alphabet comprises 29 letters due to the elimination of some 
similar-looking letters - for example, the number 0 and letters O and D, the number 8 and 
letter B, the number 5 and letter S, the number 2 and letter Z, and the number 1 and letter I, 
15 letters V and U, Of these, the letters D, V, Z, S, I, and B were retained, while the others 
were eliminated. Thus, the 29-letter used to generate the 10-digit code will include the 
following letters: 
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ABCDEFGHUKLMNPQRSTVWXYZ34679 



Referring now to FIG. 15, the encryption process will now be described. The ultimate 
goal of the encryption process is to generate a 10-digit code that will be printed on the bottle 
5 caps. Initially, a 48-bit string SI will be created. This 48-bit string includes a 32-bit integer 
number portion and a 16-bit validation portion. The 32-bit integer number portion is merely 
the numbers from 1 to 2 billion, since approximately 2 billion unique codes will be generated. 
The 16-bit validation portion is generated from the 32-bit integer number portion. 

To generate the validation portion, an internally known 128-bit secret key KEYl is first 
10 selected. A second string S2 includes the combination of KEYl and the integer number. 
Usmg this KEYl, a well-known hash algorithm, such as MD5, is applied to string S2 to 
generate string S3, As known to those ordinarily skilled in the art, MD5 is a one-way hash 
function to generate an output string. A one-way hash takes an input string SI and transforms 
it into an output string S2. It is designed so that "decryption" is not possible. In other words, 
15 it is not possible to take S2, and generate SI from it. In the current scheme, the key Kl is 
appended (or prepended) to the input string - SI +K1 = SI'. Sr is then run through the one 
way hash to generate S2. 

In this scheme, knowing the output string will not yield the input. This string S3 is a 
128-bit string. Given this 128-bit string S3, the 16 most significant bits can be used as the 16- 
20 bit validation portion of the 48-bit string SI. Of course, any 16-bit portion of this 128-bit 

string S3 can be used without much difficulty. In the present embodiment, the first 16 bits are 
used. 

Given the 48-bit string SI and a second internally known 128-bit secret key KEY2, the 
well-known DES3 encryption algorithm is applied to the string SI. This creates a 48-bit 
25 encrypted string S4. By converting this 48-bit encrypted string S4 to base 29 (for the 29 letters 
in the current alphabet), the 10-digit bottle cap code is generated. If the conversion results in a 
base 29 number that has less than 10 digits, then the system will prepend as many letter "A" as 
possible to generate the 10-digit code. This 10-digit code is printed on the bottle cap. 
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In this embodiment, a user cannot generate a new code without three pieces of 
information: (1) algorithm, (2) secret key KEYl for the one-way hash, and (3) secret key 
KEY2 for the DES3 encryption. Even if a user discovered the algorithm, this embodiment 
uses a 128-bit secret key for DES3 and a 128-bit secret key for the one-way hash. Guessing 
5 256 bits for the secret keys is almost unpossible since there are 2^^^ possible key values. 

In another embodiment of the present invention, the special codes are generated in a 
random manner. A list of approximately 2 billion codes can be generated from the number 
space. One form of a pseudo-random number generating algorithm uses a seed number and 
then generates a sequence of numbers following that seed number. If the same seed number is 

10 used, then the same sequence of numbers will be produced. 

Another, and better, form of random number generating algorithm mcorporates some 
truly random data to further mix up the seed number. This random data is usually from the 
user's computing environment, such as hard disk seek times and time between key strokes. 
Such an algorithm produces a very good set of random numbers that is most likely 

15 unreproducible even if the same seed number is used. In addition, some measures are taken to 
ensure that the same codes are not generated and that the generated codes are well-spaced 
across the number space. These codes are then entered into a production database (similar to 
the bottle cap code database). 

14,2.3 VERIFICATION 

20 Having generated and printed the special codes on the bottle caps, the Integrated Points 

System must verify that the bottle cap code that the user submitted online is indeed a valid 
bottle cap code. Referring now to FIG. 16, the user submits the 10-digit bottle cap code 
S4base29- Any prepended "A's" can be removed or otherwise ignored. This code is, of 
course, in base 29 and should be converted to base 2 form to generate S4base2* 

25 This string S4base2 is decrypted using DES3 and the secret key KEY2, which is of 

course known to the Integrated Points System. This decryption operation results in the string 
sr. This string SI' includes a validation portion (first 16 bits) and an integer number portion 
(last 32 bits) that may or may not correspond to those of the valid string SI (see FIG. 15). 
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Using the secret key KEYl and the number portion from the string ST, a second string 
S2' is created. The well-known MD5 algorithm is applied to S2' to generate the string S3\ 
The first 16 bits of this string S3' are now compared to the first 16 bits (the validation portion) 
of the string Sr 'calculated above. If these 16 bits match, then the code that the user submitted 
5 is a valid code. Thereafter, this code is checked off in the code database so that others cannot 
use this same valid code again. However, if these 16 bits do not match, then the code that the 
user submitted is an invalid code. 

In another embodiment, truly random codes are used. In this case, the encryption 
portion of the Integrated Points System implements an algorithm that incorporates some truly 
10 random data to further mix up the seed number. As mentioned above, this random data is 

usually from the user's computing environment, such as hard disk seek tunes and time between 
key strokes. Such an algorithm produces a very good set of random numbers that is most 
likely unreproducible even if the same seed number is used. These codes are then entered into 
a production database (similar to the bottle cap code database). When the points program is 
15 publicly launched and users submit codes, these codes will be checked against the database to 
ensure that any valid codes that were submitted cannot be submitted again in the future. 
14.2.4 DATABASE MANAGEMENT 

Returning to FIG. 12, the user database 402 contains information about each user's 
account. Normally, only a user with an account (i.e., member) gets the benefit of this 

20 Integrated Points System with points, coupons, and merchandise. The account information 
includes account balance (points or otherwise), expiration date for each point or group of 
points, redemption information, credit card information, billing information, billing address, 
and whether the account is authorized for using points for credit. The user's account is 
updated as points are earned or spent. 

25 In one embodiment, the user database is updated by the bottle cap code server 401 

directly as shown by dotted line 409. Thus, as codes are verified when users submit them, 
these valid codes must be checked off in the bottle cap code production database 401 so that 
these same codes cannot be used again. The nefarious user may attempt to submit the same 
valid code multiple times in hopes of earning more and more points. To curb this behavior (or 
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otherwise prevent this behavior from affecting the account points balance), the bottle cap code 
server 401 flags those codes that have been verified and thereafter, these codes will no longer 
be available for further use. In other words, if the user submits a previously verified code, the 
bottle cap server will send an error message to the web server, which will in turn deliver an 
5 error message to the user at his web browser that the code that he submitted cannot be used. 
In addition, the bottle cap server will not update the user's account in the user database with 
the points associated with this previously verified code. 

In another embodiment, the web server 400 updates the user database 402. As codes 
are verified by the bottle cap server 401, the bottle cap server 401 checks off the codes and 

10 also alerts the web server 400 to update the user's account. The web server 400 updates the 
user's account in the user database 402 to reflect the recent transaction (e.g., points earned 
from verification of proper bottle cap code). 

Referring now to FIG. 17, the database portion of the bottle cap code server and 
production database 401 is shown. In particular, FIG. 17 shows the manner in which the 

15 bottle cap codes are stored therein. In one embodiment, the actual numbers on the left column 
are not stored in memory. However, the verification flags are stored. If the verification flag 
is "0," this indicates that the number corresponding to this flag has not been verified yet. If 
the verification flag is "1," this indicates that the number corresponding to this flag has been 
verified and cannot be used again. 

20 Instead of the number itself (i.e., 1, 2, 3, ... , 1999999999, and 2000000000), a pointer 

to the appropriate corresponding flag is used. For example, if a code corresponding to number 
"3" is being verified, the pointer finds the verification flag corresponding to the third entry in 
memory and finds that a "1" is stored therein. This indicates that this code has already been 
verified and cannot be used again. The bottle cap server notes this and sends a message or 

25 error to either the web server 400 or the user database 402, depending on the embodiment. 
The web server would then alert the user of the error. 

In this embodiment, only 2 billion bits (i.e., the verification flags themselves) are 
stored in memory. This requires at least 250 MB of memory. In one embodiment, the 
memory is the conventional random access memory (RAM) with battery backup. Also, as the 

97 

SV/103327.01 
08142000/13:06/18568.1 



codes are redeemed, these redeemed codes are stored in memory. Assuming a 20% 
redemption estimate, approximately 400 million codes or 4 GB of data are needed for the 
production database. If a user breaks into this database, the entire set of 2 billion codes is not 
available since they are not stored therein. Instead, the user can only download the redeemed 
5 codes which are basically useless. However, the secret keys KEYl and KEY2 need to be 
guarded closely. Since these keys are in the production database or bottle cap code server sin 
some form, the server/production database is physically and electronically secure. In one 
embodiment, the server and database that maintains these secret keys are in a physically and 
electronically secure cage that conforms to international banking standards. 

10 In another embodiment, truly random codes are used. In this case, the encryption 

portion of the Integrated Points System implements an algorithm that incorporates some truly 
random data to further mix up the seed number. As mentioned above, this random data is 
usually from the user's computing environment, such as hard disk seek times and time between 
key strokes. Such an algorithm produces a very good set of random numbers that is most 

15 likely unreproducible even if the same seed number is used. These codes are then entered into 
a production database (similar to the bottle cap code database). When the points program is 
publicly launched and users submit codes, these codes will be checked against the database to 
ensure that any valid codes that were submitted cannot be submitted again in the future. 
The size of the production database is roughly 2 billion 10-character codes, or 

20 approximately 20 GB of database storage. This database is physically and electronically very 
secure. If a hacker breaks into the database somehow either physically or electronically, these 
list of codes could be downloaded. In one embodiment, the server and database that maintains 
these codes are in a physically and electronically secure cage that conforms to international 
banking standards, 

25 As for verifying the code is a valid code, the implemented approach is to store the full 

10 digit string of every valid code received. Then, when a new valid code is received, it is 
checked against the database of received codes to make sure it hasn't been used before. Since 
20% redemption is expected, that would be 400 million valid codes, which would require 4GB 
of storage. This solution takes advantage of the fact that the codes were generated using the 
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encryption algorithm described above. When the system validates a code, the 10 digit code 
decrypts to a single number between 1 and 2 billion. So when a valid code is received, the 
system sets the corresponding validation bit to 1 in the database. This requires storing 2 billion 
bits of data, or 250 MB. 
5 The foregoing description of a preferred embodiment of the invention has been 

presented for purposes of illustration and description. It is not intended to be exhaustive or to 
limit the invention to the precise forms disclosed. Obviously, many modifications and 
variations will be apparent to practitioners skilled in this art. One skilled in the art will readily 
appreciate that other applications may be substituted for those set forth herein without 
10 departing from the spirit and scope of the present invention. Accordingly, the invention should 
only be limited by the claims included below. 
What is claimed is: 
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CLAIM 

1 1, An offline-online points system, comprising: 

2 a main server for providing a user with an interface to submit a code, wherein the user 

3 obtained the code offline and the code is associated with N points; and 

4 a code server for maintaining valid codes and verifying that the code that the user 

5 submitted is a valid code. 

2. The system of claim 1, further comprising: 
a user database that maintains an account of the user, wherein the account balance is M 

points prior to the user's submission of the code. 

3. The system of claim 2, wherein the code server updates the account balance to M+N 
points after the user submits the code and if the code server verifies that the code is valid. 

4. The system of clarni 2, wherein the main server updates the account balance to M+N 
points after the user submits the code if the code server verifies that the code is valid. 

1 5. The system of claim 2 wherein the code is C letters in length from an alphabet of L 
n 2 letters, 

1 6. The system of claim 5 wherein C is 10. 

1 7. The system of claim 6 wherein L is 29. 

1 8. The system of claim 6 wherein L is 36. 

19. A method of generating an encrypted code in base L, comprising steps: 

2 providing an n-bit raw nimiber; 

3 applying a one-way hash function on the n-bit raw number with a first secret key to 

4 generate a first string; 
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5 
6 
7 



designating an m-bit portion of the first string as an m-bit validation number; and 
combining the m-bit validation number and the n-bit raw number to generate a second 

string. 



1 10. The method of claim 9, further comprismg steps: 

2 applying a DES3 encryption algorithm to the second string with a second secret key to 

3 generate a thu:d string; and 

4 converting the third string to base L to generate the encrypted code. 



1 



11. 



The method of claim 9, wherein n=32, m=16, and L=29. 



1 



12. 



The method of claim 9, wherein the one-way hash function is MD5. 



2 



1 



13. 



The method of claim 9, wherein the step of combining includes: 
concatenating the m-bit validation number and the n-bit raw number. 



1 14. The method of claim 13, wherein the m-bit validation number is the most significant bit 

2 (MSB) portion of the second string. 

1 15. The method of claim 9, wherein the m-bit validation number is the m most significant 

2 bit (MSB) of the first string. 

1 16. A method of verifying the validity of a code, comprising steps: 

2 generating a code with encrypted information; 

3 providing the code on a hard good to be distributed to users; 

4 receiving the code online; and 

5 verifying the validity of the code by processing the encrypted information. 

1 17. The method of claim 16, wherein the step of generating includes steps: 

2 providing an n-bit raw number; 

3 applying a one-way hash function on the n-bit raw number with a first secret key to 

4 generate a first string; 

5 designating an m-bit portion of the first string as an m-bit validation number; 
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6 combining the m-bit validation number and the n-bit raw number to generate a second 

7 string; 

8 applying a DES3 encryption algorithm to the second string with a second secret key to 

9 generate a third string; and 

10 converting the third string to base L to generate the code with the encrypted 

1 1 information. 

1 18. The method of claim 17, wherein the step of verifying includes: 

2 converting the code in base L to generate a first test code in base 2; 

3 decrypting the first test code with the second secret key using a reverse DES3 

4 encryption algorithm to generate a second test code; 

5 applying the one-way hash algorithm to the second test code to generate a third test 

6 code; and 

7 comparing a designated m-bit portion of the second test code to a designated m-bit 

8 portion of the third test code, and if the comparison is positive, declaring the code to be valid. 

1 19. The method of claun 18, wherein the m-bit validation number is the m most significant 

2 bit (MSB) of the first string in the generating step and the designated m-bit portion is the most 

3 significant bit portion of the second test code and third test code in the comparing step. 

1 20. A method for awarding incentive points to a user, comprising steps: 

2 generating a code with encrypted information; 

3 providing the code to an entity for printing on a hard good; 

4 receiving the code submitted by the user; and 

5 verifying the validity of the code by processmg the encrypted information. 

1 21. The method of claim 20, wherein the step of generating includes steps: 

2 providing an n-bit raw number; 

3 applying a one-way hash function on the n-bit raw number with a first secret key to 

4 generate a first string; 

5 designating an m-bit portion of the first string as an m-bit validation number; 
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6 combining the m-bit validation number and the n-bit raw number to generate a second 

7 string; 

8 applying a DES3 encryption algorithm to the second string with a second secret key to 

9 generate a third string; and 

10 converting the third string to base L to generate the code with the encrypted 

11 information. 

1 22. The method of claim 21, wherein the step of verifying includes: 

2 converting the code in base L to generate a first test code in base 2; 

3 decrypting the first test code with the second secret key using a reverse DES3 

4 encryption algorithm to generate a second test code; 

5 applying the one-way hash algorithm to the second test code to generate a third test 

6 code; and 

7 comparing a designated m-bit portion of the second test code to a designated m-bit 

8 portion of the third test code, and if the comparison is positive, declaring the code to be valid. 

1 23. The method of claim 22, wherein the m-bit validation number is the m most significant 

2 bit (MSB) of the first string in the generating step and the designated m-bit portion is the most 

3 significant bit portion of the second test code and third test code in the comparing step. 



103 



SV/ 103327 .01 
08142000/13:06/18568.1 



ABSTRACT 

An electronic points system that allows consumers to redeem online those points that 
were earned offline is described. In one implementation, the offline-online points system is 
applied to a soft drink bottle caps program. A soft drink company is sponsoring a promotions 

5 program where certain bottle caps are worth so many points. A consumer buys a soft drink 
bottle at a local store. The lucky consumer discovers that he is the beneficiary of a winning 
bottle cap, and in particular, a bottle cap that is worth N points. Instead of redeeming this 
winning bottle cap in the traditional way, the consumer logs onto the soft drink company's 
website and registers his bottle cap code. Thereafter, after registration, the consumer can 

10 redeem these points for any merchandise that is available for purchase with these points at any 
participating company's online store. 
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VERIFICATION 
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DECLARATION, POWER OF ATTORNEY AND PETITION 

As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name. 

I believe I am an original, first and joint inventor of the subject matter which is claimed and for which a patent is 
sought on the invention entitled "Offline-Online Incentive Points System" the specification of which 

(check one) EI is attached hereto 

□ was filed on as Application Serial No. 

and was amended on (if applicablej. 



I hereby state that I have reviewed and understand the contents of the above identified specification, including the 
claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the examination of this ^plication in accordance 
with Title 37, Code of Federal Regulations, § L56(a). 

I hereby claim foreign priority benefits under Title 35, United States Code, § 1 19 of any foreign application(s) or U.S. 
provisional application(s) for patent or inventor's certificate listed below and have also identified below any foreign application 
or U.S. provisional application(s) for patent or inventor's certificate having a filing date before that of the application of which 
priority is claimed. 

PRIOR FOREIGN/U.S. PROVISIONAL APPLICATION(S) 

Priority Claimed 



(Number) (Country)(Day, month, year filed) Yes No 



(Number) (Country)(Day, month, year filed) Yes No 



(Number) (Country)(Day, month, year filed) Yes No 

I hereby claim the benefit under Title 35, United States Code, § 120 of any United States application(s) listed below 
and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States application in 
the manner provided by the first paragraph of Title 35, United States Code, § 1 12, I acknowledge the duty to disclose material 
information as defined in Title 37, Code of Federal Regulations, § L56(a) which occurred between the filing date of the prior 
application and the national or PCT intemational filing date of this application: 



(Application Serial No.) Filing Date (Status: Patented, pending, abandoned) 



(Application Serial No.) Filing Date (Status: Patented, pending, abandoned) 

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with the knowledge that willful false 
statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Tiile 18 of the United 
States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon. 

And I hereby appoint W. POMS, Reg. 18,782; G.P. SMITH, Reg. 20,142; G.E. LANDE, Reg. 22,222; A.C, ROSE, 
Reg. 17,047; LJ. BOVASSO, Reg, 24,075; D.J. OLDENKAMP, Reg. 29,421; C. DARROW, Reg. 30,166; M.E. HARRIS, 
Reg. 26,690; K. A. MACLEAN, Reg. 31,118; C ROSENBERG, Reg. 31,464; M.E. BROWN, Reg. 28,590; E.F. O'CONNOR, 
Reg. 25,903; R.F. CARR, Reg. 17,110; A, ROTHENBERG, Reg. 17,843; RL. GAUSEWITZ, Reg. 16,960; M.A. 
KONDZELLA, Reg. 18,013; A.P, BLOCK, Reg. 35,450; S.R. HANSEN, Reg. 38,486; D.N. LARSON, Reg. 29,401; J.W. 
INSKEEP, Reg. 33,910; G.F. COTTERELL, Reg. 37,802; H.D. JASTRAM, Reg. 19,777; C.J. LERVICK, Reg. 35,244; 
C.A.S. HAMRICK, Reg. 22,586; RO. GUILLOT, Reg. 28,852; J.D. VOELZKE, Reg. 37,957; G.L. FOUNTAIN, Reg. 36,374; 
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S408 731 3520 YAHOO!, INC. 

^kus-Uiim 13:30 Fron-OPPENHEIMER 



08/14/00 14:44 P. 003/005 
HE3 P.QQ3/DD5 F-B34 



Poclci; No,; 18567-0012 



J, 80YCE, Reg. ^0,920, C CHOU, Keg. 41,672; A^, DlKPENBW)Clt, Reg. 39960; MK- BOSWORTH, Reg 2^.m, 
OPPENHEIMER WOLFF & DONNEUY LLP, 3373 KiUvjcw Avcnue, Suilc 20Q, Palo Alio. California 9430*, (650) 320-4000, 
us my urtoracys wirfi dill po^ct of s«bst|tuiion aixl r=vocarion. to prosecute said application ancJ to imnsaci m connecnoTi 
tncrcv^lth All basmcss in the Patent ma Trademark Otrlcc sma before comp^teni Intemuticnal Auihorlttcs, 

A44rcss all usicphone oillji lo Ctiicn-Wci (Cnris) ChOM w (^08) 320-4000 an«i afidpesa 4I1 cont>pon4encc u>: 

CHIEN-WEI (CHRJSj CHOU, ESQ, 
OPPENHEIMEB WOLFF 4 DONNELLY LLP 
3373 BitLVIEW aV^UB, SUITE 200 
PaLO alto. CALIFORNIA 94304 

WHcTcforc 1 prB> thai LcrtBis Faiem be granted id tne for tHe invention or 4j5cove;> described und claimed iri ifte 
forcgoiAg spcclf\C9S\on mA claims^ and I hetet^y subscribe m> ns^ie to the farct^oing iptcifiCdtioz) »i4 cfat ms, dc^Jaranon. power 
of asorney, »nd ibis peEioon. 



FuH Natne of First Inventor: 
Home A<ldfcii: 
Post Office Addrtss: 
Cnt2cosh1p: 
tovcntof Sigtwiurc: 

Full >lanic of Second Lnvcnton 

HomcAdditss: 

Post OfiQce Address: 

Ctcjjxnship: 

Inventor's Signdiun;; 

Fall Name of Third InvenTar. 
Hatnc AiSdr^is: 
Post Office Address- 
CUittnsblp: 
Iliv<niior*s Slgjwaire: 



Eric Buvd 



Same gftovc 




00 



1920 San Rjtifion Avcnue, Mountain V>ey. CA 94043 



Same as ^bovc 




Anil Pal 



1370 Yujcflii Terrace, SonnWalc.CA 940B7 



Same aa' above 



Uniicd Kinadom 



Fijll Nunc of Fourth Inventor: 
HoTne Address: 
PosiTOfpcc Address: 

inven^ir'ik Ssgnarurc; 



David Rornan 



1058 Ashbury Sircsci, San Francisco, CA 94 II 7 



Same as aljovc 
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